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CHAPTER 1. INTRODUCTION 


The Seattle Computer DiskMaster!™ gives system designers a 
flexible, high performance floppy disk controller for the 

S-100 (IEE-696) bus. The DiskMaster supports both 8-inch 

and 5.25-inch floppy disk drives. 


As many as four 8-inch and four 5.25-inch drives, in any 
combination, may be controlled simultaneously by a single 
DiskMaster. This makes it easy to transfer data between 8- 
inch and 5.25-inch disks within the sytem. 


A patent-pending digital data separator design provides 
unsurpassed data recovery reliability. This digital 
technique enhances data recovery reliability over older, 
less accurate analog techniques. As a result, the 
DiskMaster has a wider tolerance for the varying read/write 
data speeds of floppy disks from other systems. 


odode’ See 


[(eIeIe)} 


Hoo 06 oraaooatOioa a 


DISK MASTER 


Supe 5 O00 
sl oooolBOG0QOUL 


Introduction 


FEATURES 


Handles up to eight disk drives, four 8-inch and four 
5.25-inch. 


Physically and electrically separate connectors for 8- 
inch and 5.25-inch disk drives to eliminate crosstalk 
and overloading of signal drivers. 


Configuration header to handle the different pin 
arrangement of 8-inch drives. 


Complete automatic hardware support for disk drives 
with voice-coil head positioners. 


Complete automatic hardware support for disk drives 
with spindle-motor control. 


A breakthrough in data separator design for unsurpassed 
data-recovery reliability (patent pending). 


Based on the Western Digital 1793 disk controller chip. 
(The data sheet for the 1793 chip is found in Appendix 
A.) 


Full compliance with the IEEE-696 standard. 
Direct Memory Access capability when combined with 
Seattle Computer's Direct Memory Access Controller 


board. 


Allows easy transfer of data and software between 8- 
inch drives and 5.25-inch drives. 


CHAPTER 2. SWITCH AND JUMPER SETTINGS 
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DiskMaster Switch Locations 


Switch and Jumper Settings 


‘MOT ON 


MOTOR OFF 
DELAY 


VI 01234567INT DMA 
RUPT 
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DiskMaster 
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LARGE MOT 
ON 
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PRECOMP 


WAIT PROG AUTO 
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Jumper Locations 


Switch and Jumper Settings 


BUS INTERFACE SWITCHES AND JUMPERS 
PORT ADDRESS Switch 


The DiskMaster requires six I/O ports that are grouped 
consecutively starting on any 8-port boundary called the 
BASE. The BASE is selected using the top five positions of 
the PORT ADDRESS switch. These top five positions are 
labeled A7-A3 and correspond to address lines A7-A3 on the 
bus. The bottom three positions of the PORT ADDRESS switch 
are not used. 


Switch settings I/O port 


address base 


A6 AS A4 A3 
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*BASE address used by Seattle Computer 
I/O systems 


Switch and Jumper Settings 


» a 
INTERRUPT Jumper lured yrs 


Interrupts from the DiskMaster can be sent to any of the 
eight vectored Interrupt lines VIO-VI7 or directly to the 
INT line for systems without interrupt controllers. Place 
the blue shunt over one of the nine vertical pairs of pins 
corresponding to interrupt lines VIO-VI7 or INT. 


If none of the interrupt lines should be used, put the shunt 
on any two of the pins in the upper row. 


WAIT Jumper tonal Dvr 


This jumper selects whether or not the DiskMaster asks for 
wait-states when the CPU talks to the 1793 disk controller 
chip. The WAIT jumper should be in the ON position forall 
CPUs faster than a 2-MHz 8080 or Z80. With the WAIT jumper 
in the ON position, the number of wait states asked for 
depends on the CPU speed: the faster the CPU's clock, the 
more wait-states will be requested. 


Switch and Jumper Settings 


The following instructions are only necessary if you have a 
DMA controller in your system. 


DMA PRIORITY Switch 


This switch selects the DMA priority to which the Disk 
Master will respond. Since the DMA controller is not 
located on the DiskMaster board, the DiskMaster monitors 
the S-100 bus to determine when a DMA cycle is being run for 
it. The DMA priority lines are used to determine when the 
DiskMaster's DMA controller (one of up to sixteen possible 
DMA controllers) is active. The DMA PRIORITY switches are 
labeled DMA 0-3 on the board to the left of the switch and 1 
and 0 above the switch. 


Switch settings 


DMA DMA DMA DMA Priority Priority 
3 2 1 0 (hex) (decimal) 


Lowest priority 
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Highest priority 


DMA Jumper 


The DiskMaster sends DMA requests to the Direct Memory 

Access Controller board using one of the NDEF pins of 

the S-100 bus. This jumper selects which pin is used. 
Qu CH1 Pin 65 


CH2 Pin 66 


Switch and Jumper Settings 


DISK INTERFACE JUMPERS AND HEADERS 


AUTO MOT/SM AUTO/ON Jumper 


This jumper lets the DiskMaster know which drives have 
spindle motors that are under its control. This is a four- 
position jumper. To choose one of the three settings, place 
the blue shunt over the jumpers pins as shown below. 


AUTO MOT DiskMaster controls motors of both 
SM AUTO 8-inch and 5.25-inch drives. Place the 
AUTO ON shunt over the two leftmost jumper 
MOT Hiie9 pins. 
SM AUTO DiskMaster controls 5.25-inch 
SM AUTO spindle motors; 8-inch spindle motors 
AUTO ON are assumed to be always on. Place the 
MOT [life] shunt over the two center jumper pins. 
ON Spindle motors of both 8-inch and 
SM AUTO 5.25-inch drives are assumed to be 
AUTO ON always on. Place the shunt over the 
.MOT bona two rightmost jumper pins. 


LARGE MOT ON Jumper 


This jumper controls the polarity of the MOTOR ON signal 
going to the 8-inch disk drives. Most standard-height 
8-inch drives have AC spindle motors that cannot be turned 
on and off, so the setting of this jumper is irrelevant when 
using these drives. 


lwilf LO Active-low motor-on (PerSci drives) 


HI Active-high motor-on (Tandon drives) 


MOT ON Jumper 


This jumper selects how long the DiskMaster waits for the 
spindle motors to come up to speed. 


F 1/2 second 


x. arentes 1 second 


Switch and Jumper Settings 


MOTOR OFF DELAY Jumper 


This jumper selects how long the DiskMaster will keep the 
spindle motors going after the disk heads have been 
unloaded. 


F 7.5 seconds 


vet § 15 seconds 


HEAD LOAD Jumper 


This jumper selects whether 8-inch drives use the HEAD 
LOAD signal or the DRIVE SELECT signal to load the heads. 


HL Drives use HEAD LOAD signal 


we DS Drives use DRIVE SELECT signal 


FAST SEEK Jumper 


This jumper selects whether the 8-inch drives have standard 
stepper motor head positioners or voice coil head 
positioners. 


ON voice coil positioner 


lvveedy OFF Stepper motor positioner 


PRECOMP Jumper 


This jumper selects whether write precompensation is 

turned on and off by the 1793 disk controller chip using the 
TG43 signal, or whether write precompensation is enabled by 
a bit in the Auxiliary Command port. If the 1793 controls 
write précompensation, it will be turned on for all tracks 
beyond track 43. Write compensation is not used with 
single-density. 


No precompensation is required for a Seattle Computer system 
with Mitsubishi drives. 


Caner PROG Write precompensation controlled by 
Auxiliary Command port. 


AUTO Write precompensation controlled by 1793's 
TG43 signal. 


eee 


Switch and Jumper Settings 
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PIN 18 Jumper | 


This jumper selects whether pin 18 of the/50-pin connector 
for 8-inch drives are used for head load or for spindle 
motor control. Mitsubishi half-height drives use this line 
for motor control; most other drives ignore the signal or 
use it for head load. 


iy WL Send HEAD LOAD signal to pin 18 


MOT Send MOTOR ON signal to pin 18 


8-Inch Drive Configuration Header 


This sixteen-pin socket is found in location J3 (between 
ICl17 and IC18). It can be used to re-arrange the signals on 
the 50-pin connector for the 8-inch drives (this is required 
for PerSci drives). 


J3 
connector 
Signals from Pin Pin J1 50-pin 
disk controller no. no. connector 


DRIVE SELECT 4 


RESTORE 1 

DISK CHANGE 2 
SIDE SELECT 3 
TG43 4 

DRIVE SELECT 3 2) 
HEAD LOAD 6 

7 

8 


The signals tor the standard drive are shown below, along 
with the signals as rearranged for the PerSci drive. 


J3 J3 
Standard drive) (PerSci drive) 


Pin Pin 
no. no. 
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CHAPTER 3. I/O PORTS 


The DiskMaster uses a total of six I/O ports for 
communication with the CPU. These six ports can be set on 
any eight-port boundary called the BASE. See the 
description of how to select the BASE under "PORT ADDRESS 
Switch" in Section 2. 


The six I/O ports are used as follows: 


BASE+0 - 1793 Command/Status 


register See the Western 
BASE+1 - 1793 Track register Digital data sheet 
BASE+2 - 1793 Sector register in Appendix A 


BASE+3 - 1793 Data register 
BASE+4 - Auxiliary Command/Status 

port Described below 
BASE+5 - Wait Synchronization port 


The 1793 uses the first four ports. For more information, 
refer to the Western Digital 1793 data sheet in Appendix A. 
AUXILIARY COMMAND PORT 

The Wait Synchronization I/O port is BASE+4 (see the 
description of how to select the BASE under "PORT ADDRESS 


Switch" in Section 2. 


The bits of the auxiliary command port are: 


DMA “DMA Double | Side DS1 DSO 
write | enable|comp 


density 
wu te 
restore 
Bit 7 controls the DMA direction. The DMA direction refers 
to the direction of the memory access, not the disk access. 
DMA WRITE should be low when DMA ENABLE is low; otherwise 
RESTORE will be activated (see "RESTORE" below). 


DMA WRITE Bit 


Bit 7 = 0 Read memory (write disk) 


=] Write memory (read disk) 


ll 


I/O Ports 


DMA ENABLE Bit 


Bit 6 controls whether DMA requests are passed to the DMA 
controller and whether the DiskMaster responds to DMA 
cycles on the bus. 


To turn off DMA, be sure to turn off both DMA ENABLE 
and DMA WRITE; otherwise RESTORE will be activated (see 
"RESTORE Function" below). 


Bit 6 = 0 DMA requests are not sent to the DMA 
controller; DiskMaster ignores DMA 
cycles on the bus. 


=1 DMA requests are sent to the DMA 
controller; DiskMaster responds to DMA 
cycles on the bus. 


RESTORE Function 


The RESTORE function for PerSci drives is activated by 
setting setting bits 6 and 7 as follows: 


Bit 6 = 0 
Bit 7 = 1 


If you do not have PerSci drives, all RESTORE does is load 
the head of the selected drive. This can be a handy way to 
keep the head loaded to perform head alignment or other disk 
drive maintenance. 


PRECOMP ENABLE Bit 


Bit 5 controls whether or not write precompensation is used 
when writing to double-density disks. It also controls the 
low WRITE CURRENT CURRENT or TRACK GREATER THAN 43 (TG43) 
signal to 8-inch drives. If the PRECOMP jumper (see "Disk 
Interface Jumpers and Headers") is in the AUTO position this 
bit does nothing: write precompensation and write current 
are controlled by the TG43 signal from the 1793 disk 
controller chip. 


Bit 5 = 0 Disable precompensation 


= 1 Enable precompensation 
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I/O Ports 


SMALL DRIVE Bit 


Bit 4 selects whether a 5.25-inch drive or an 8-inch drive 
is being used. When 5.25-inch drives are selected, the 8- 
inch drive selects are disabled, and vice-versa. It is this 
feature which allows having four 8-inch drives and four 
5.25-inch drives connected to the DiskMaster at the same 
time. 


Bit 4 8-inch drive 


i] 
oO 


= 1 5.25-inch drive 


DOUBLE-DENSITY Bit 
Bit 3 selects single- or double-density operation. 
Bit 3 = 0 Single-density 


= 1 Double-density 


SIDE Bit 
Bit 2 selects side 0 or 1 of double-sided disks. 


Bit 2 0 Side 0 


= 1 Side l 


DS1 and DSO BITS 


Bit 1 (DS1) and bit 0 (DSO) select one of four drives of 
5.25-inch or 8-inch size. 


: Dsl DSO Drive 
(bit 1) (bit 0) selected 


PO a 


I/O Ports 


AUXILIARY STATUS PORT 


The bits of the auxiliary status port are described below. 


Disk Two- Head 
change] sided | load 


X = Undefined bits with no particular value. 


Interrupt 
request 


DISK CHANGE Bit 


Many Shugart- type 8-inch disk drives provide a Disk Change 
signal on pin 12 of the 50-pin connector which can be read 
using this status bit. If the disk has been changed, the 
Disk Change bit (bit 7) will be low. 


TWO-SIDED/SEEK COMPLETE Bit 


If your 8-inch drives are standard Shugart-type double-sided 
drives, there is probably a TWO-SIDED signal on pin 10 of 
the 50-pin connector which can be read using this status 
bit. When a double-sided disk is used, this bit (bit 6) 
will be high. 


If your 8-inch drives are PerSci drives, the state of the 
Seek Complete signal can be read using this bit. This bit 
will be high when the seek is completed. 

HEAD LOAD Bit 

Bit 5 will be high when the disk drive head is loaded 
(including a head-load forced by RESTORE). 

INT ERRUPL REQUEST Bit 

The state of the 1793's interrupt request pin can be read 


using bit 0. If this bit is high, the disk controller is 
requesting an interrupt. 
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I/O Ports 


WAIT SYNCHRONIZATION PORT 


The Wait Synchronization port performs the same function as 
the Auxiliary Command/Status port. The only exception is 
that any access of this port holds the CPU in wait states 
until either Interrupt Request or Data Request from the 1793 
disk controller chip become active. This port is usually 
used to make the CPU wait until the 1793 disk controller is 
ready to transfer data in non-DMA systems. 


The Wait Synchronization I/O port is BASE+5 (see the 


description of how to select the BASE under "PORT ADDRESS 
Switch" in Section 2). 


Be: 


— 


I/O Ports 


APPENDIX A. WESTERN DIGITAL DATA SHEET 


WESTERN DIGITAL 


Cc O R P A T f QO WN 


FD179X- 02 
Floppy Disk Formatter/Controller Family 


FEATURES ¢ PROGRAMMABLE CONTROLS 
© TWOVFOCONTROL SIGNALS — RG & VFOE Selectable Track to Track Stepping Time 
° SOFT SECTOR FORMAT COMPATIBILITY Side Select Compare 
* AUTOMATIC TRACK SEEK WITH VERIFICATION * INTERFACES TO WD1691 DATA SEPARATOR 
* ACCOMMODATES SINGLE AND DOUBLE DENSITY *¢ WINDOW EXTENSION 
FORMATS * INCORPORATES ENCODING/DECODING AND 
IBM 3740 Single Density (FM) ADDRESS MARK CIRCUITRY 
IBM System 34 Double Density (MFM) ¢ FD1792/4 IS SINGLE DENSITY ONLY 
Non IBM Format for Increased Capacity * FD1795/7 HAS A SIDE SELECT OUTPUT 
¢ READ MODE 179X-02 FAMILY CHARACTERISTICS 
Single/Multiple Sector Read with Automatic Search or 


1792 
Single Density (FM) X 
Double Density (MFM) 
True Data Bus 


Entire Track Read 
Selectable 128, 256, 512 or 1024 Byte Sector Lengths 
e WRITE MODE 
Single/Multiple Sector Write with Automatic Sector 
Search 


~{ fj "| 
x [>< 


Entire Track Write for Diskette Formatting Inverted Data Bus 
e SYSTEM COMPATIBILITY Write Precomp 
Double Buffering of Data 8 Bit Bi-Directional Bus for Side Selection Output 
Data, Control and Status 
DMA or Programmed Data Transfers APPLICATIONS 
Allinputs end Outputs are TTL Compatioie 8” FLOPPY AND 51%" MINI FLOPPY CONTROLLER 
On-Chip Track and Sector Registers/Comprehensive SINGLE OR DOUBLE DENSITY 
coms yiomatin CONTROLLER/FORMATTER 


RAW READ. 


} Vopi + 12V) 
oD RG/SSO 


179X 


pmacvEe00o 


FLOPPY DISK 
CONTROLLER 
FORMATTER 


AO-O <VvVOrN 


) RAW READ 
) RCLK 


mornwvwmaz— 
mornwmaAaZz— 


cc (+5V) 


*1791/3 = RG 1795/7 = SSO 
**1793/7 TRUE BUS TIEUGEDY 
***1792/4 OPEN 


PIN CONNECTIONS 


FD179X SYSTEM BLOCK DIAGRAM 


c0-X6Z104 


Western Digital Data Sheet 


PIN OUTS 


NO CONNECTION 


MASTER RESET 


20-X6Z1-GA4 


POWER SUPPLIES 


COMPUTER INTERFACE: 
2 WRITE ENABLE 


CHIP SELECT: 
READ ENABLE 


REGISTER SELECT LINES 


DATA ACCESS LINES DALO-DAL7 


DATA REQUEST 


INTERRUPT REQUEST 


FLOPPY DISK INTERFACE: 
STEP 
DIRECTION 


EARLY 
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Pin 1 is internally connected to a back bias generator and 
must be left open by the user. 


A logic low (50 microseconds min.) on this input resets the 
device and loads HEX 03 into the command register. The Not 
Ready (Status Bit 7) is reset during MR ACTIVE. When MR is 
brought to a logic high a RESTORE Command is executed, 
regardiess of the state of the Ready signal from the drive. 
Also, HEX 01 is loaded into sector register. 


Ground 
+5V +5% 
+12V +5% 


A logic low on this input gates data on the DAL into the 
selected register when CS is low. 


A logic low on this input selects the chip and enables 
computer communication with the device. 


A logic low on this input controls the placement of data froma 
selected register on the DAL when CS is low. 


These inputs select the register to receive/transter data on the 
DAL lines under RE and WE control: 
CS Ai AO RE WE 
Status Reg Command Reg 
Track Reg Track Reg 


0 Sector Reg Sector Reg 
4 Data Reg Data Reg 


Eight bit Bidirectional bus used for transfer of data, control, 
and status. This bus is receiver enabled by WE or transmitter 
enabled by RE. Each line will drive 1 standard TTL load. 


This input requires a free-running 50% duty cycle square wave 
clock for internal timing reference, 2 MHz + 1% for 8" drives, 
1 MHz + 1% for mini-floppies. 


This open drain output indicates that the DR contains 
assembled data in Read operations, or the DR is empty in 
Write operations. This signal is reset when serviced by the 
computer through reading or loading the DR in Read or Write 
operations, respectively. Use 10K pull-up resistor to + 5. 


This open drain output is set at the completion of any com- 
mand and is reset when the STATUS register is read or the 
command register is written to. Use 10K pull-up resistor to 
+5, 


The step output contains a pulse for each step. 


Direction Output is active high when stepping in, active low 
when stepping out. 


Indicates that the WRITE DATA pulse occuring while Early is 
active (high) should be shifted early for write precom- | 
pensation. 


Indicates that the write data pulse occurring while Late is 
active (high) should be shifted late for write precompensation. 


Western Digital Data Sheet 


PIN 
NUMBER 


PIN NAME 
TEST 


HEAD LOAD TIMING 


READ GATE 
(1791, 1792, 1793, 1794) 


SIDE SELECT OUTPUT 
(1795, 1797) 


READ CLOCK 


RAW READ 
HEAD LOAD 


TRACK GREATER THAN 43 


WRITE GATE 


WRITE DATA 


READY 


WRITE FAULT 
VFO ENABLE 


TRACK 00 


SYMBOL FUNCTION 


TEST 


HLT 


RG 


Sso 


RCLK 


RAW READ 
HLD 


TG43 


WG 


WD 


READY 


WF/VFOE 


TROO 


This input is used for testing purposes only and should be tied | 
to +5V or left open by the user unless interfacing to voice coil | 
actuated steppers. | 


When a logic high is found on the HLT input the head is 
assumed to be engaged. It is typically derived from a 1 shot 
triggered by HLD. 


This output is used for synchronization of external data 
separators. The output goes high after two Bytes of zeros in 
single density, or 4 Bytes of either zeros or ones in double 
density operation. 


The logic level of the Side Select Output is directly controlled 
by the ‘S’ flag in Type II or Ill commands. When U = 1, SSO is 
set to a logic 1. When U = 0, SSO is set to a logic 0. The SSO 
is compared with the side information in the Sector |.D. Field. 
If they do not compare Status Bit 4 (RNF) is set. The Side 
Select Output is only updated at the beginning of a Type Il or 
{ll command. It is forced to a logic 0 upon a MASTER RESET 
condition. 


A nominal square-wave clock signal derived from the data 
stream must be provided to this input. Phasing (i.e. RCLK 
transitions) relative to RAW READ is important but polarity 
(RCLK high or low) is not. 


The data input signal directly from the drive. This input shall 
be a negative pulse for each recorded flux transition. 


The HLD output controls the loading of the Read-Write head 
against the media. 


This output informs the drive that the Read/Write head is 
positioned between tracks 44-76. This output is valid only 
during Read and Write Commands. 


This output is made valid before writing is to be performed on 
the diskette. 


A 200 ns (MFM) or 500 ns (FM) output pulse per flux transition. 
WD contains the unique Address marks as well as data and 
clock in both FM and MFM formats. 


This input indicates disk readiness and is sampled for a logic 
high before Read or Write commands are performed. If Ready 
is low the Read or Write operation is not performed and an 
interrupt is generated. Type | operations are performed 
regardless of the state of Ready. The Ready input appears in 
inverted format as Status Register bit 7. 


This is a bi-directional signal used to signify writing faults at 
the drive, and to enable the external PLO data separator. When 
WG = 1, Pin 33 functions as a WF input. If WF = 0, any write 
command will immediately be terminated. When WG = 0, Pin 
33 functions as a VFOE output. VFOE will go low during a read 
operation after the head has loaded and settled (HLT = 1). On 
the 1795/7, it will remain low until the last bit of the second 
CRC byte in the ID field. VFOE will then go high until 8 bytes 
(MFM) or 4 bytes (FM) before the Address Mark. It will then go 
active until the last bit of the second CRC byte of the Data 
Field. On the 1791/3, VFOE will remain low until the end of the 
Data Field. This pin has an internal 100K Ohm pull-up resistor. 


This input informs the FD179X that the Read/Write head is 
positioned over Track 00. 
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z0-X6Z1-04 


c0-X6Z1-C4 


Western Digital Data Sheet 


PIN NUMBER| —PINNAME —|_— SYMBOL FUNCTION 


WRITE PROTECT 


DOUBLE DENSITY 


35 INDEX PULSE This input informs the FD179X when the index hole is en- 
36 
37 


countered on the diskette. 

This input is sampled whenever a Write Command is received. 
GENERAL DESCRIPTION 
The FD179X are N-Channel Silicon Gate MOS LSI 


A logic low terminates the command and sets the Write 
devices which perform the functions of a Floppy Disk 


Protect Status bit. 
This input pin selects either single or double density 
operation. When DDEN = 0, double density is selected. When 
DDEN = 1, single density is selected. This line must be left 
Formatter/Controller in a single chip implementation. 
The FD179X, which can be considered the end result 
of both the FD1771 and FD1781 designs, is IBM 3740 
compatible in single density mode (FM) and System 34 
compatible in Double Density Mode (MFM). The 
FD179X contains all the features of its predecessor the 
FD1771, plus the added features necessary to 
read/write and format a double density diskette. These 
include address mark detection, FM and MFM encode 
and decode logic, window extension, and write precom- 
pensation. In order to maintain compatibility, the 
FD1771, FD1781, and FD179X designs were made as 
close as possible with the computer interface, instruc- 
tion set, and W/O registers being identical. Also, head 
load control is identical. In each case, the actual pin 
assignments vary by only a few pins from any one to 
another. 
The processor interface consists of an &bit bi-direc- 
tional bus for data, status, and control word transfers. 
The FD179X is set up to operate on a multiplexed bus 
with other bus-oriented devices. 
The FD179X is TTL compatible on all inputs and 
outputs. The outputs will drive ONE TTL load or three 
LS loads. The 1793 is identical to the 1791 except the 
DAL lines are TRUE for systems that utilize true data 
busses. 
The 1795/7 has a side select output for controlling 
double sided drives, and the 1792 and 1794 are “Single 
Density Only” versions of the 1791 and 1793 respec- 
tively. On these devices, DDEN must be left open. 


ORGANIZATION 


The Floppy Disk Formatter block diagram is illustrated 
on page 5. The primary sections include the parallel 
processor interface and the Floppy Disk interface. 


Data Shift Register — This &bit register assembles 
serial data from the Read Data input (RAW READ) 
during Read operations and transfers serial data to the 
Write Data output during Write operations. 

Data Register — This S&bit register is used as a 
holding register during Disk Read and Write operations. 
In Disk Read operations the assembled data byte is 
transferred in parallel to the Data Register from the 
Data Shift Register. In Disk Write operations in- 
formation is transferred in parallel from the Data 
Register to the Data Shift Register. 


ip 
WPRT 
DDEN 


open on the 1792/4. 


When executing the Seek command the Data Register 
holds the address of the desired Track position. This 
register is loaded from the DAL and gated onto the 
DAL under processor control. 

Track Register — This 8bit register holds the track 
number of the current Read/Write head position. It is 
incremented by one every time the head is stepped in 
(towards track 76) and decremented by one when the 
head is stepped out (towards track 00). The contents of 
the register are compared with the recorded track 
number in the ID field during disk Read, Write, and 
Verify operations. The Track Register can be loaded 
from or transferred to the DAL. This Register should 
not be loaded when the device is busy. 

Sector Register (SR) — This 8-bit register holds the address 
of the desired sector position. The contents of the register 
are compared with the recorded sector number in the ID 
field during disk Read or Write operations. The Sector 
Register contents can be loaded from or transferred to the 
DAL. This register should not be loaded when the device is 
busy. 

Command Register (CR) — This &bit register holds the 
command presently being executed. This register should 
not be loaded when the device is busy unless the new 
command is a force interrupt. The command register can 
be loaded from the DAL, but not read onto the DAL. 

Status Register (STR) — This 8bit register holds device 
Status information. The meaning of the Status bits is a 
function of the type of command previously executed. This 
register can be read onto the DAL, but not loaded from the 
DAL. 

CRC Logic — This logic is used to check or to generate the 
16-bit Cyclic Redundancy Check (CRC). The polynomial is: 
G(x) = x'® + x"? + x8 + 1. 

The CRC includes all information starting with the address 
mark and up to the CRC characters. The CRC register is 
Preset to ones prior to data being shifted through the 
circuit. 

Arithmetic/Logic Unit (ALU) — The ALU is a serial com- 
parator, incrementer, and decrementer and is used for 
register modification and comparisons with the disk 
recorded ID field. 


Timing and Control — All computer and Floppy Disk In- 
terface controls are generated through this logic. The in- 
ternal device timing is generated from an external crystal 
clock. 

The FD179X has two different modes of operation ac- 
cording to the state of DDEN. When DDEN = 0 double 
density (MFM) is assumed. When DDEN = 1, single 
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density (FM) is assumed. 1792 & 1794 are single density 
only. 


AM Detector — The address mark detector detects ID, data 
and index address marks during read and write operations. 


PROCESSOR INTERFACE 


The interface to the processor is accomplished through the 
eight Data Access Lines (DAL) and associated control 
signals. The DAL are used to transfer Data, Status, and 
Control words out of, or into the FD179X. The DAL are three 
State buffers that are enabled as output drivers when Chip 
Select (CS) and Read Enable (RE) are active (low logic state) 
or act as input receivers when CS and Write Enable (WE) 
are active. 


When transfer of data with the Floppy Disk Controller is 
required by the host processor, the device address is 
decoded and CS is made low. The address bits A1 and AO, 
combined with the signals RE during a Read operation or 
WE during a Write operation are interpreted as selecting 
the following registers: 


READ (RE) 
Status Register 
Track Register 
Sector Register 
Data Register 


WRITE (WE) 
Command Register 
Track Register 
Sector Register 
Data Register 


During Direct Memory Access (DMA) types of data 
transfers between the Data Register of the FD179X and the 
processor, the Data Request (DRQ) output is used in Data 
Transfer control. This signal also appears as status bit 1 
during Read and Write operations. 


On Disk Read operations the Data Request is activated (set 
high) when an assembled serial input byte is transferred in 
parallel to the Data Register. This bit is cleared when the 
Data Register is read by the processor. If the Data Register 
is read after one or more characters are lost, by having new 
data transferred into the register prior to processor readout, 
the Lost Data bit is set in the Status Register. The Read 
operation continues until the end of sector is reached. 


On Disk Write operations the data Request is activated 
when the Data Register transfers its contents to the Data 
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Shift Register, and requires a new data byte. It is reset 
when the Data Register is loaded with new data by the 
processor. If new data is not loaded at the time the next 
serial byte is required by the Floppy Disk, a byte of zeroes 
is written on the diskette and the Lost Data bit is set in the 
Status Register. 

At the completion of every command an INTRQ is 
generated. INTRQ is reset by either reading the status 
register or by loading the command register with a new 
command. In addition, INTRQ is generated if a Force 
Interrupt command condition is met. 

The 179X has two modes of operation according to the 
state of DDEN (Pin 37). When DDEN = 1, single density is 
selected. In either case, the CLK input (Pin 24) is at 2 MHz. 
However, when interfacing with the mini-floppy, the CLK 
input is set at 1 MHz for both single density and double 
density. 

GENERAL DISK READ OPERATIONS 

Sector lengths of 128, 256, 512 or 1024 are obtainable in 
either FM or MFM formats. For FM, DDEN should be 
placed to logical “1.” For MFM formats, DDEN should be 
placed to a logical “0.” Sector lengths are determined at 
format time by the fourth byte in the “ID” field. 


Sector Length Table* 


Sector Length Number of Bytes 
Field (hex in Sector (decimal 


*1795/97 may vary — see command summary. 

The number of sectors per track as far as the FD179X is 
concerned can be from 1 to 255 sectors. The number of 
tracks as far as the FD179X is concerned is from 0 to 255 
tracks. For IBM 3740 compatibility, sector lengths are 128 
bytes with 26 sectors per track. For System 34 com- 
patibility (MFM), sector lengths are 256 bytes/sector with 26 
sectors/track; or lengths of 1024 bytes/sector with 8 
sectors/track. (See Sector Length Table) 

For read operations in 8” double density the FD179X 
requires RAW READ Data (Pin 27) signal which is a 200 ns 
pulse per flux transition and a Read clock (RCLK) signal to 
indicate flux transition spacings. The RCLK (Pin 26) signal 
is provided by some drives but if not it may be derived 
externally by Phase lock loops, one shots, or counter 
techniques. In addition, a Read Gate Signal is provided as 
an output (Pin 25) on 1791/92/93/94 which can be used to 
inform phase lock loops when to acquire synchronization. 
When reading from the media in FM. RG is made true when 
2 bytes of zeroes are detected. The FD179X must find an 
address mark within the next 10 bytes; otherwise RG is 
reset and the search for 2 bytes of zeroes begins all over 
again. If an address mark is found within 10 bytes, RG 
remains true as long as the FD179X is deriving any useful 
information from the data stream. Similarly for MFM, RG is 
made active when 4 bytes of “00” or “FF” are detected. The 
FD179X must find an address mark within the next 16 
bytes, otherwise RG is reset and search resumes. 

During read operations (WG = 0), the VFOE (Pin 33) is 
provided for phase lock loop synchronization. VFOE will go 
active low when: 


a) Both HLT and HLD are True 
b) Settling Time, if programmed, has expired 
c) The 179X is inspecting data off the disk 


\f WF/VFOE is not used, leave open or tie to a 10K resistor 
to +5. 

GENERAL DISK WRITE OPERATION 

When writing is to take place on the diskette the Write Gate 
(WG) output is activated, allowing current to flow into the 
Read/Write head. As a precaution to erroneous writing the 
first data byte must be loaded into the Data Register in 
response to a Data Request from the FD179X before the 
Write Gate signal can be activated. 

Writing is inhibited when the Write Protect input is a logic 
low, in which case any Write command is immediately 
terminated, an interrupt is generated and the Write Protect 
status bit is set. The Write Fault input, when activated, 
signifies a writing fault condition detected in disk drive 
electronics such as failure to detect write current flow 
when the Write Gate is activated. On detection of this fault 
the FD179X terminates the current command, and sets the 
Write Fault bit (bit 5) in the Status Word. The Write Fault 
input should be made inactive when the Write Gate output 
becomes inactive. 

For write operations, the FD179X provides Write Gate (Pin 
30) and Write Data (Pin 31) outputs. Write data consists of a 
series of 500 ns pulses in FM (ODEN = 1) and 200 ns 
pulses in MFM (DDEN = 0). Write Data provides the unique 
address marks in both formats. 

Also during write, two additional signals are provided for 
write precompensation. These are EARLY (Pin 17) and 
LATE (Pin 18). EARLY is active true when the WD pulse 
appearing on (Pin 30) is to be written EARLY. LATE is active 
true when the WD pulse is to be written LATE. If both 
EARLY and LATE are low when the WD pulse is present, 
the WD pulse is to be written at nominal. Since write 
precompensation values vary from disk manufacturer to 
disk manufacturer, the actual value is determined by 
several one shots or delay lines which are located external 
to the FD179X. The write precompensation signals EARLY 
and LATE are valid for the duration of WD in both FM and 
MFM formats. 


READY 

Whenever a Read or Write command (Type Il or Ill) is 
received the FD179X samples the Ready input. If this input 
is logic low the command is not executed and an interrupt 
is generated. All Type | commands are performed re- 
gardless of the state of the Ready input. Also, whenever a 
Type II or Il] command is received, the TG43 signal output 
is updated. 


COMMAND DESCRIPTION 

The FD179X will accept eleven commands. Command 
words should only be loaded in the Command Register 
when the Busy status bit is off (Status bit 0). The one 
exception is the Force Interrupt command. Whenever a 
command is being executed, the Busy status bit is set. 
When a command is completed, an interrupt is generated 
and the Busy status bit is reset. The Status Register 
indicates whether the completed command encountered 
an error or was fault free. For ease of discussion, 
commands are divided into four types. Commands and 
types are summarized in Table 1. 
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TABLE 1. COMMAND SUMMARY 
A. Commands for Models: 1791, 1792, 1793, 1794 B. Commands for Models: 1795, 1797 


Restore 
Seek 
Step 
Step-in 
Step-out 


20-X6Z+-04 


Read Sector 
Write Sector 
Read Address 
Read Track 
Write Track 
Force Interrupt 


ae seas COCCOI!N 
3422400000] 
onm-30-0-0-00|um 
==-o0035 3 777+ Off 


ao 
DS 


Command 
Type 
0 = Stepping Motor Rate 
See Table 3 for Rate Summary 


V = Track Number Verify Flag 


h = Head Load Flag , Load head at beginning 
, Unload head at beginning 


T = Track Update Flag , No update 
, Update track register 


@0 = Data Address Mark 40 = 0, FB(DAM) 

40 = 1, F8 (deleted DAM) 
C = Side Compare Flag = 0, Disable side compare 
= 1, Enable side compare 


0, Update SSO to 0 
1, Update SSO to 1 


W& il U = Update SSO 


Cc 
Cc 
U 
U 


W& il E = 15 MS Delay , No 15 MS delay 
, 15 MS delay 


S = Side Compare Flag 0, Compare for side 0 
1, Compare for side 1 


LSB’s Sector Length in ID Field 
01 10 11 


512 1024 128 
512 1024 


L = Sector Length Flag 


m = Multiple Record Flag m = 0, Single record 
m = 1, Multiple records 


Interrupt Condition Flags 
1 Not Ready To Ready Transition 
1 Ready To Not Ready Transition 
= 1Index Pulse 
= 1Immediate Interrupt, Requires A Reset 
I3l0 = 0 Terminate With No Interrupt (INTRQ) 


*NOTE: See Type lV Command Description for further information. 
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TYPE | COMMANDS 


The Type | Commands include the Restore, Seek, Step, 
Step-In, and Step-Out commands. Each of the Type | 
Commands contains a rate field (fO ™), which determines 
the stepping motor rate as defined in Table 3. 

A 2 us (MFM) or 4 us (FM) pulse is provided as an output to 
the drive. For every step pulse issued, the drive moves one 
track location in a direction determined by the direction 
output. The chip will step the drive in the same direction it 
last stepped unless the command changes the direction. 
The Direction signal is active high when stepping in and 
low when stepping out. The Direction signal is valid 12 us 
before the first stepping pulse is generated. 


The rates (shown in Table 3) can be applied to a Step- 
Direction Motor through the device interface. 


TABLE 3. STEPPING RATES 


CLK 2MHz 2 MHz 1 MHz 1 MHz 2 MHz 


DDEN 0 1 0 1 x 


TEST=1 TEST=1 TEST=1 TEST=0 


R1 RO TEST=1 


After the last directional step an additional 15 milliseconds 
of head settling time takes place if the Verify flag is set in 
Type | commands. Note that this time doubles to 30 ms for 
a1 MHz clock. If TEST = 0, there is zero settling time. 
There is also a 15 ms head settling time if the E flag is set in 
any Type II or Ill command. 


When a Seek, Step or Restore command is executed an 
optional verification of Read-Write head position can be 
performed by settling bit 2(V = 1) in the command word to 
a logic 1. The verification operation begins at the end of the 
15 millisecond settling time after the head is loaded against 
the media. The track number from the first encountered ID 
Field is compared against the contents of the Track 
Register. If the track numbers compare and the ID Field 
Cyclic Redundancy Check (CRC) is correct, the verify 
operation is complete and an INTRQ is generated with no 
errors. If there isa match but not a valid CRC, the CRC error 
Status bit is set (Status bit 3), and the next encountered ID 
field is read from the disk for the verification operation. 


The FD179X must find an ID field with correct track number 
and correct CRC within 5 revolutions of the media; 
otherwise the seek error is set and an INTRQ is generated. 
If V = 0, no verification is performed. 


The Head Load (HLD) output controls the movement of the 
read/write head against the media. HLD is activated at the 
beginning of a Type! command if the h flag is set(h = 1), at 
the end of the Type | command if the verify flag (V = 1), or 
upon receipt of any Type II or Ill command. Once HLD is 
active it remains active until either a Type | command is 
received with (h = 0 and V = 0); or if the FD179X is in an 
idle state (non-busy) and 15 index pulses have occurred. 


Head Load timing (HLT) is an input to the FD179X which is 
used for the head engage time. When HLT = 1, the FD179X 
assumes the head is completely engaged. The head 
engage time is typically 30 to 100 ms depending on drive. 
The low to high transition on HLD is typically used to fire a 
one shot. The output of the one shot is then used for HLT 
and supplied as an input to the FD179Xx. 


HLD | 


¢ [50 to 100ms ——>} 
' 
1 


HLT (FROM ONE SHOT) 


HEAD LOAD TIMING 


When both HLD and HLT are true, the FD179X will then 
read from or write to the media. The “and” of HLD and HLT 
appears as status Bit 5 in Type | status. 


In summary for the Type | commands: if hh = 0 and V = 0, 
HLD is reset. If h = 1 and V = O, HLD is set at the 
beginning of the command and HLT is not sampled nor is 
there an internal 15 ms delay. Ifh = 0 and V = 1, HLD is 
set near the end of the command, an internal 15 ms occurs, 
and the FD179X waits for HLT to be true. Ifh = 1 andV = 
1, HLD is set at the beginning of the command. Near the 
end of the command, after all the steps have been issued, 
an internal 15 ms delay occurs and the FD179X then waits 
for HLT to occur. 


For Type Il and Ill commands with E flag off, HLD is made 
active and HLT is sampled until true. With E flag on, HLD is 
made active, an internal 15 ms delay occurs and then HLT 
is sampled until true. 


RESTORE (SEEK TRACK 0) 


Upon receipt of this command the Track 00 (TROO) input is 
sampled. If TROO is active low indicating the Read-Write 
head is positioned over track 0, the Track Register is loaded 
with zeroes and an interrupt is generated. If TROO is not 
active low, stepping pulses (pins 15 to 16) at a rate specified 
by the "1 '0 field are issued until the TROO input is activated. 
At this time the Track Register is loaded with zeroes and an 
interrupt is generated. If the TROO input does not go active 
low after 255 stepping pulses, the FD179X terminates 
operation, interrupts, and sets the Seek error status bit, 
providing the V flag is set. A verification operation also 
takes place if the V flag is set. The h bit allows the head to 
be loaded at the start of command. Note that the Restore 
command is executed when MR goes from an active to an 
inactive state and that the DRQ pin stays low. 


SEEK 


This command assumes that the Track Register contains 
the track number of the current position of the Read-Write 
head and the Data Register contains the desired track 
number. The FD179X will update the Track register and 
issue stepping pulses in the appropriate direction until the 
contents of the Track register are equal to the contents of 
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the Data Register (the desired track location). A verification 
operation takes place if the V flag is on. The h bit allows the 
head to be loaded at the start of the command. An interrupt 
is generated at the completion of the command. Note: 
When using multiple drives, the track register must be 
updated for the drive selected before seeks are issued. 


STEP 


Upon receipt of this command, the FD179X issues one 
stepping pulse to the disk drive. The stepping motor 
direction is the same as in the previous step command. 
After a delay determined by the '1!0 field, a verification 
takes place if the V flag is on. If the U flag is on, the Track 
Register is updated. The h bit allows the head to be loaded 
at the start of the command. An interrupt is generated at 
the completion of the command. 


STEP-IN 


Upon receipt of this command, the FD179X issues one 
stepping pulse in the direction towards track 76. If the U 


a 
-1TOTR *1TOTR 


1s 
HEAD AT 
TRACK 0 AND 
DIRECTION 
a) 


1s 
OMMAND 
‘A STEP. STEP-IN, 
OR STEP-OUT, 
> 
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flag is on, the Track Register is incremented by one. After a 
delay determined by the '1'0 field, a verification takes place 
if the V flag is on. The h bit allows the head to be loaded at 
the start of the command. An interrupt is generated at the 
completion of the command. 


STEP-OUT 


Upon receipt of this command, the FD179X issues one 
stepping pulse in the direction towards track 0. If the U flag 
is on, the Track Register is decremented by one. After a 
delay determined by the '1'0 field, a verification takes place 
if the V flag is on. The h bit allows the head to be loaded at 
the start of the command. An interrupt is generated at the 
completion of the command. 


EXCEPTIONS 


On the 1795/7 devices, the SSO output is not affected 
during Type 1 commands, and an internal side compare 
does not take place when the (V) Verify Flag is on. 
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VERIFY 
SEQUENCE 


INTRO RESET BUSY 


HAS 
sus 
EXPIRED 
7 


INTRO. RESET BU 
SET SEEK ERROR } 


10 AM BEEN 
DETECTED 
7 


TR TRACK 
ADORESS OF ID 
FIELO 
7 


's 
THERE A 
CRC ERROR 
7 


INTRO. 
RESET BUSY 


NOTE: ag = 0, THERE IS NO 15MS DELAY 
= 1ANOCLK = 1 MHz, THERE IS A 30MS DELAY 


TYPE | COMMAND FLOW 


TYPE I! COMMANDS 


The Type Ii Commands are the Read Sector and Write 
Sector commands. Prior to loading the Type |i Command 
into the Command Register, the computer must load the 
Sector Register with the desired sector number. Upon 
receipt of the Type !! command, the busy status Bit is set. If 
the E flag = 1 (this is the normal case) HLD is made active 
and HLT is sampled after a 15 msec delay. If the E flag is 0, 
the head is loaded and HLT sampled with no 15 msec 
delay. The ID field and Data Field format are shown on page 
13. 

When an ID field is located on the disk, the FD179X 
compares the Track Number on the ID field with the Track 
Register. If there is not a match, the next encountered ID 
field is read and a comparison is again made. If there was a 
match, the Sector Number of the ID field is compared with 
the Sector Register. If there is not a Sector match, the next 
encountered ID field is read off the disk and comparisons 
again made. If the ID field CRC is correct, the data field is 


then located and will be either written into, or read from 
depending upon the command. The FD179X must find an 
ID field with a Track number, Sector number, side number, 
and CRC within four revolutions of the disk; otherwise, the 
Record not found status bit is set (Status bit 3) and the 
command is terminated with an interrupt. 


COMMAND 
RECEIVED 
7 


SET BUSY, RESET DRO, LOST 
DATA, RECORD NOT FOUND. & 
STATUS BITS 5 & 6 INTRO 


INTRO 
RESET BUSY 


SET HLO 


Lae 
1smMs* 


EXPIRED 
2 


INTRO. RESET BUSY 
SET WRITE PROTECT 


“NOTE: IF TEST = 0, THERE IS NO 15MS DELAY 
i = 1AND CLK = 1 MHz, THERE IS 30MS DELAY 


TYPE Il COMMAND 
Each of the Type Il Commands contains an (m) flag which 
determines if multiple records (sectors) are to be read or 
written, depending upon the command. If m = 0, a single 
sector is read or written and an interrupt is generated at the 
completion of the command. If m = 1, multiple records are 
read or written with the sector register internally updated 
so that an address verification can occur on the next 
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record. The FD179X will continue to read or write multiple 
records and update the sector register in numerical 
ascending sequence until the sector register exceeds the 
number of sectors on the track or until the Force Interrupt 
command is loaded into the Command Register, which 
terminates the command and generates an interrupt. 


For example: If the FD179X is instructed to read sector 27 
and there are only 26 on the track, the sector register ex- 
ceeds the number available. The FD179X will search for 5 
disk revolutions, interrupt out, reset busy, and set the 
record not found status bit. 


The Type Il commands for 1791-94 also contain side select 
compare flags. When C = 0 (Bit 1) no side comparison is 
made. When C = 1, the LSB of the side number is read off 
the ID Field of the disk and compared with the contents of 
the (S) flag (Bit 3). If the S flag compares with the side 
number recorded in the ID field, the FD179X continues with 
the ID search. If a comparison is not made within 5 index 
pulses, the interrupt line is made active and the Record- 
Not-Found status bit is set. 


ADORESS OF ID 
FIELD 
? 


BRING IN SECTOR LENGTH FIELD 
STORE LENGTH IN INTERNAL 
REGISTER 


Is 
SET CRC THERE A 
STATUS ERROR cRC Enon 


TYPE I| COMMAND 
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The Type Il and III commands for the 1795-97 contain a side 
select flag (Bit 1). When U = 0, SSO is updated to 0. 
Similarly, U = 1 updates SSO to 1. The chip compares the 
SSO to the ID field. If they do not compare within 5 
revolutions the interrupt line is made active and the RNF 
Status bit is set. 


The 1795/7 READ SECTOR and WRITE SECTOR com- 
mands include a ‘L’ flag. The ‘L’ flag, in conjunction with 
the sector length byte of the ID Field, allows different byte 
lengths to be implemented in each sector. For IBM 
compatability, the ‘L’ flag should be set to a one. 


READ SECTOR 


Upon receipt of the Read Sector command, the head is 
loaded, the Busy status bit set, and when an ID field is 
encountered that has the correct track number, correct 
sector number, correct side number, and correct CRC, the 
data field is presented to the computer. The Data Address 


READ SECTOR 
SEQUENCE 


HAS 
FIRST BYTE 
BEEN ASSEMBLED 
IN DSR 


INTRO. RESET BUSY 
SET CRC ERROR 
INTRO RESET BUSY 
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WRITE SECTOR 
SEQUENCE 


DELAY 2 BYTES OF GaP 


DELAY 8 BYTES OF GAP 


fr: 
‘OR BEEN 
LOADED BY 
COMPUTER 
(ORO = 0 
? 


INTRO, RESET BUSY 
SET LOST DATA 


YES 


DELAY 1 BYTE OF GAP 


YES 


TURN ON WG 4 WRITE 


6 BYTES OF ZEROS DELAY 11 BYTES 


TURN ON WG & WRITE 
12 BYTES OF ZEROS 


WRITE DATA AM 
ACCORDING TO AO FIELD 
OF WRITE COMMAND 


OR TO OSA. SET ORO 


WRITE BYTE TO DISK 


HAS 
OR BEEN NO SET DATA 
LOADED LOST 


(ORQ = 0) WRITE BYTE 
? OF ZEROS 


ves 
WRITE CRC 
WRITE 1 BYTE OF FF 


TURN OFF WG 


HAVE 
ALL BYTES 
BEEN WRITTEN 
? 


TYPE I| COMMAND 


Mark of the data field must be found within 30 bytes in 
single density and 43 bytes in double density of the last ID 
field CRC byte; if not, the ID field is searched for and 
verified again followed by the Data Address Mark search. If 
after 5 revolutions the DAM cannot be found, the Record 
Not Found status bit is set and the operation is terminated. 
When the first character or byte of the data field has been 
shifted through the DSR, it is transferred to the DR, and 
DRQ is generated. When the next byte is accumulated in 
the DSR, it is transferred to the DR and another DRQ is 
generated. If the Computer has not read the previous 
contents of the DR before a new character is transferred 
that character is lost and the Lost Data Status bit is set. 
This sequence continues until the complete data field has 
been inputted to the computer. If there is a CRC error at the 
end of the data field, the CRC error status bit is set, and the 
command is terminated (even if it is a multiple record 
command). 

At the end of the Read operation, the type of Data Address 
Mark encountered in the data field is recorded in the Status 
Register (Bit 5) as shown: 


STATUS 
BIT5 
it Deleted Data Mark 
0 Data Mark 


WRITE SECTOR 


Upon receipt of the Write Sector command, the head is 
loaded (HLD active) and the Busy status bit is set. When an 
ID field is encountered that has the correct track number, 
correct sector number, correct side number, and correct 
CRC, a DRQ is generated. The FD179X counts off 11 bytes 
in single density and 22 bytes in double density from the 
CRC field and the Write Gate (WG) output is made active if 
the DRQ is serviced (i.e., the DR has been loaded by the 
computer). If DRQ has not been serviced, the command is 
terminated and the Lost Data status bit is set. If the DRQ 
has been serviced, the WG is made active and six bytes of 
zeroes in single density and 12 bytes in double density are 
then written on the disk. At this time the Data Address 
Mark is then written on the disk as determined by the 40 
field of the command as shown below: 


ao Data Address Mark (Bit 0) 
1 Deleted Data Mark 
0 Data Mark 


The FD179X then writes the data field and generates DRQ’s 
to the computer. If the DRQ is not serviced in time for 
continuous writing the Lost Data Status Bit is set and a 
byte of zeroes is written on the disk. The command is not 
terminated. After the last data byte has been written on the 
disk, the two-byte CRC is computed internally and written 
on the disk followed by one byte of logic ones in FM or in 
MFM. The WG output is then deactivated. For a 2 MHz 
clock the INTRQ will set 8 to 12 usec after the last CRC byte 
is written. For partial sector writing, the proper method is to 
write the data and fill the balance with zeroes. By letting the 
chip fill the zeroes, errors may be masked by the lost data 
status and improper CRC Bytes. 


TYPE II1 COMMANDS 


READ ADDRESS 


Upon receipt of the Read Address command, the head 
is loaded and the Busy Status Bit is set. The next 
encountered ID field is then read in from the disk, and 
the six data bytes of the ID field are assembled and 
transferred to the DR, and a DRQ is generated for each 
byte. The six bytes of the ID field are shown below: 


TRACK sio—E | sector | SECTOR aes 
ADDR | NUMBER | ADDRESS | LENGTH | 1 | 2 
fr 1| 2 i] 3 {[ 4 {sje} 


Although the CRC characters are transferred to the 
computer, the FD179X checks for validity and the CRC 
error status bit is set if there is a CRC error. The Track 
Address of the ID field is written into the sector 
register so that a comparison can be made by the 
user. At the end of the operation an interrupt is 
generated and the Busy Status is reset. 
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READ TRACK 


Upon receipt of the READ track command, the head Is 
loaded, and the Busy Status bit is set. Reading starts with 
the leading edge of the first encountered Index pulse and 
continues until the next Index pulse. All Gap, Header, and 
data bytes are assembled and transferred to the data 
register and DRQ's are generated for each byte. The ac- 
cumulation of bytes is synchronized to each address mark 
encountered. An Interrupt is generated at the completion of 
the command. 


This command has several characteristics which make It 
suitable for diagnostic purposes. They are: the Read Gate 


ves 


BETHLO 


COPY S FLAG TO 


TYPE Ili COMMAND WRITE TRACK 


is not activated during the command; no CRC checking is 
performed; gap information is included in the data stream; 
the internal side compare is not performed; and the ad- 
dress mark detector is on for the duration of the command. 
Because the A.M. detector is always on, write splices or 
noise may cause the chip to look for an A.M. If an address 
mark does not appear on schedule the Lost Data status flag 
Is set. 


The ID A.M., ID field, ID CRC bytes, DAM, Data, and Data 
CRC Bytes for each sector will be correct. The Gap Bytes 
may be read incorrectly during write-splice time because of 
synchronization. 


YES (MFM) 


WRITE 2 CRC 
CHARS. CLK = FF 


WRITE FC 
CLK = O7 


WRITE FO, FE OR 
F8-FB,CLK = C7 
INITIALIZE CAC 


INTRO RESET BUSY 


WRITE 
BYTE OF ZEROS 
SET DATALOST 


WRITE At’ IN MEM 
WITH MISSING CLOCK 
INITIALIZE CRC 


WRITE C2" IN MFM 
WITH MISSING CLOCK 
WRITE 2 CRC 
CHARS 


NO 
WRITE DSA 
IN MEM 


TYPE Ili COMMAND WRITE TRACK 
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CONTROL BYTES FOR INITIALIZATION 


DATA PATTERN 
IN DR (HEX) 


00 thru F4 


Not Allowed 
Not Allowed 
Generate 2 CRC bytes 


Write FC with Clk = D7 
Write FD with Clk = FF 


Write FF with Clk = FF 


*Missing clock transition between bits 4 and 5 


WRITE TRACK FORMATTING THE DISK 
(Refer to section on Type III commands for flow diagrams.) 


Formatting the disk is a relatively simple task when 
operating programmed I/O or when operating under DMA 
with a large amount of memory. Data and gap information 
must be provided at the computer interface. Formatting the 
disk is accomplished by positioning the R/W head over the 
desired track number and issuing the Write Track com- 
mand. 


Upon receipt of the Write Track command, the head is 
loaded and the Busy Status bit is set. Writing starts with 
the leading edge of the first encountered index pulse and 
continues until the next index pulse, at which time the 
interrupt is activated. The Data Request is activated im- 
mediately upon receiving the command, but writing will not 
start until after the first byte has been loaded into the Data 
Register. If the DR has not been loaded by the time the 
index pulse is encountered the operation is terminated 
making the device Not Busy, the Lost Data Status Bit is set, 
and the Interrupt is activated. If a byte is not present in the 
DR when needed, a byte of zeroes is substituted. 


This sequence continues from one index mark to the next 
index mark. Normally, whatever data pattern appears in the 
data register is written on the disk with a normal clock 
pattern. However, if the FD179X detects a data pattern of 
F5 thru FE in the data register, this is interpreted as data 
address marks with missing clocks or CRC generation. 


The CRC generator is initialized when any data byte from 
F8 to FE is about to be transferred from the DR to the DSR 
in FM or by receipt of F5 in MFM. An F7 pattern will 
generate two CRC characters in FM or MFM. As a con- 
sequence, the patterns F5 thru FE must not appear in the 
gaps, data fields, or ID fields. Also, CRC’s must be 
generated by an F7 pattern. 


Disks may be formatted in IBM 3740 or System 34 formats 
with sector lengths of 128, 256, 512, or 1024 bytes. 


TYPE IV COMMANDS 


The Forced Interrupt command is generally used to ter- 
minate a multiple sector read or write command or to in- 


FD179X INTERPRETATION 
IN FM (ODEN = 1) 


Write 00 thru F4 with CLK = FF 


Write F8 thru FB, Clk = C7, Preset CRC 


Write FE, Clk = C7, Preset CRC 


FD1791/3 INTERPRETATION 

IN MEM (ODEN = 0) 

Write 00 thru F4, in MFM 

Write A1* in MFM, Preset CRC 

Write C2** in MFM 

Generate 2 CRC bytes 

Write F8 thru FB, in MFM 

Write FC in MFM 

Write FD in MFM 

Write FE in MFM 

Write FF in MFM 


**Missing clock transition between bits 3 & 4 


sure Type | status in the status register. This command can 
be loaded into the command register at any time. If there is 
a current command under execution (busy status bit set) 
the command will be terminated and the busy status bit 
reset. 


The lower four bits of the command determine the con- 
ditional interrupt as follows: 


lo = Not-Ready to Ready Transition 
l1 = Ready to Not-Ready Transition 
12 = Every Index Pulse 

13 = Immediate Interrupt 


The conditional interrupt is enabled when the cor- 
responding bit positions of the command ('3 - !0) are set to 
a1. Then, when the condition for interrupt is met, the IN- 
TRQ line will go high signifying that the condition specified 
has occurred. If !3 - 'o are all set to zero (HEX D0), no in- 
terrupt will occur but any command presently under 
execution will be immediately terminated. When using the 
immediate interrupt condition (13 = 1) an interrupt will be 
immediately generated and the current command ter- 
minated. Reading the status or writing to the command 
register will not automatically clear the interrupt. The HEX 
DO is the only command that will enable the immediate 
interrupt (HEX D8) to clear on a subsequent load command 
register or read status register operation. Follow a HEX D8 
with DO command. 


Wait 8 micro sec (double density) or 16 micro sec (single 
density before issuing a new command after issuing a 
forced interrupt (times double when clock = 1 MHz). 
Loading a new command sooner than this will nullify the 
forced interrupt. 


Forced interrupt stops any command at the end of an in- 
ternal micro-instruction and generates INTRQ when the 
specified condition is met. Forced interrupt will wait until 
ALU operations in progress are complete (CRC 
calculations, compares, etc.). 


More than one condition may be set at a time. If for 
example, the READY TO NOT-READY condition (4 = 1) 
and the Every Index Pulse (12 = 1) are both set, the 
resultant command would be HEX “DA”. The “OR” func- 
tion is performed so that either a READY TO NOT- READY 
or the next Index Pulse will cause an interrupt condition. 


SRE eV ER I NT TE EO LC 


SET BUSY 
RESET STATUS 
BITS 2, 4,5 


COPY'S FLAG 
TO SSO LINE 
(1795/7 ONLY) 


“i TEST= 6, NO DELAY 
it TEST=1 and CLK=1 MHZ, 30 MS DELAY 


INTRQ 
RESET BUSY 


ADDRESS 
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READ TRACK 
SEQUENCE 


SHIFT ONE BIT 
INTO DSR 


SET INTRQ 
RESET BUSY 


ADDRESS 
MARK DETECTED 
? 


YES 


HAVE 8 
BITS BEEN 


ASSEMBLED 
? 


SET LOST 
DATA BIT 


TYPE Ill COMMAND 
Read Track/Address 
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SHIFT 1 BYTE 
INTO DSR 


TRANSFER 
BYTE TO DR 


HAVE 6 
BYTES BEEN 
READ 
? 


READ ADDRESS 
SEQUENCE 


RESET BUSY 


STATUS REGISTER 


Upon receipt of any command, except the Force Interrupt 
command, the Busy Status bit is set and the rest of the 
status bits are updated or cleared for the new command. If 
the Force Interrupt Command is received when there is a 
current command under execution, the Busy status bit is 
reset, and the rest of the status bits are unchanged. If the 
Force Interrupt command is received when there is not a 
current command under execution, the Busy Status bit is 
reset and the rest of the status bits are updated or cleared. 
In this case, Status reflects the Type | commands. 


The user has the option of reading the status register 
through program control or using the DRQ line with DMA or 
interrupt methods. When the Data register is read the DRQ 
bit in the status register and the DRQ line are automatically 
reset. A write to the Data register also causes both DRQ’s 
to reset. 


The busy bit in the status may be monitored with a user 
program to determine when a command is complete, in 
lieu of using the INTRQ line. When using the INTRQ, a busy 
status check is not recommended because a read of the 
status register to determine the condition of busy will reset 
the INTRQ line. 


The format of the Status Register is shown below: 


Status varies according to the type of command executed 
as shown in Table 4. 


Because of internal sync cycles, certain time delays must 
be observed when operating under programmed I/O. They 
are: (times double when clock = 1 MHz) 


ee 
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Delay Req'd. 
. . ! 
WAMNeEEH TRACK Operation Next Speration FM ! MFM 
NTEGIeTOR Write to Read Busy Bit 12us |; 6ys 
Command Reg. | (Status Bit 0) a 
T 
Write to Read Status 28us |; 14yus 
Command Reg. | Bits 1-7 ! 
; T : T 
Scions Write Any Read From Diff. 0 ' 0 
ERROR BIT Register Register | 


IBM 3740 FORMAT — 128 BYTES/SECTOR 


Shown below is the IBM single-density format with 128 
bytes/sector. In order to format a diskette, the user must 
issue the Write Track command, and load the data register 
with the following values. For every byte to be written, there 
is one Data Request. 


SET INTRQ 
RESET BUSY 


TYPE Ill COMMAND 
Read Track/Address 
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IBM 3740 FORMAT — 128 BYTES/SECTOR 


Shown below is the IBM single-density format with 128 
bytes/sector. In order to format a diskette, the user must 
issue the Write Track command, and load the data register 
with the following values. For every byte to be written, there 
is one Data Request. 


NUMBER HEX VALUE OF 
OF BYTES BYTE WRITTEN 


FF (or 00)' 

00 

FC (Index Mark) 

FF (or 00)' 

00 

FE (ID Address Mark) 
Track Number 

Side Number (00 or 01) 
Sector Number (1 thru 1A) 
00 (Sector Length) 

F7 (2 CRC’s written) 

FF (or 00)' 

00 

FB (Data Address Mark) 
Data (IBM uses E5) 

F7 (2 CRC’s written) 

FF (or 00)' 

FF (or 00)' 


Baad 


6 
1 
1 
1 
1 
1 
1 
1 
6 
1 


*Write bracketed field 26 times 
**Continue writing until FD179X interrupts out. 
Approx. 247 bytes. 
1-Optional ‘00’ on 1795/7 only. 


AY 
BITS 4 ANO 5 MISSING 


/*MIBSING CLOCK TRANSITION 
BETWEEN BITS 3 AND 4 


(OGar 
econo 
wre oo oyTE MF 


IBM SYSTEM 34 FORMAT. 256 BYTES/SECTOR 


Shown below is the IBM dual-density format with 256 
bytes/sector. In order to format a diskette the user must 
issue the Write Track command and load the data register 
with the following values. For every byte to be written, there 
is one data request. 


NUMBER HEX VALUE OF 
OF BYTES BYTE WRITTEN 


4E 

00 

F6 (Writes C2) 

FC (Index Mark) 

4E 

00 

F5 (Writes A1) 

FE (ID Address Mark) 
Track Number (0 thru 4C) 
Side Number (0 or 1) 
Sector Number (1 thru 1A) 
01 (Sector Length) 

F7 (2 CRCs written) 

4E 

00 

F5 (Writes A1) 

FB (Data Address Mark) 
DATA 

F7 (2 CRCs written) 

4E 

4E 


*Write bracketed field 26 times 
**Continue writing until FD179X interrupts out. 
Approx. 598 bytes. 
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1. NON-IBM FORMATS 


Variations in the IBM formats are possible to a limited 
extent if the following requirements are met: 


1) Sector size must be 128, 256, 512 or 1024 bytes. 
2) Gap 2 cannot be varied from the IBM format. 
3) 3 bytes of A1 must be used in MFM. 


In addition, the Index Address Mark is not required for 
operation by the FD179X. Gap 1, 3, and 4 lengths can be as 
short as 2 bytes for FD179X operation, however PLL lock up 
time, motor speed variation, write-splice area, etc. will add 
more bytes to each gap to achieve proper operation. It is 
recommended that the IBM format be used for highest 
system reliability. 


> | aa - 7 ssc il 
FM MFM 
Gap | 16 bytes FF 32 bytes 4E 
Gap Il 11 bytes FF 22 bytes 4E 
: 6 bytes 00 12 bytes 00 
i 3 bytes Al 
Gap III** 10 bytes FF | 24bytes 4E 
4 bytes 00 8 bytes 00 
3 bytes Al 
Gap IV 16 bytes FF 16 bytes 4E 


*Byte counts must be exact. 
**Byte counts are minimum, except exactly 3 bytes of A1 
must be written. 


TIMING CHARACTERISTICS 
Ta = 0°C to 70°C, Voo = + 12V = .6V, Vss = OV, Vcc = +5V + .25V 


READ ENABLE TIMING (See Note 6, Page 21) 


SYMBOL CHARACTERISTIC 


Setup ADDR & CS to RE_ 
Hold ADDR & CS from RE 
RE Pulse Width __ 

DRQ Reset from RE _ 
INTRQ Reset from RE 
Data Access from RE 
Data Hold From RE 


WRITE ENABLE TIMING (See Note 6, Page 21) 


SYMBOL 


Setup ADDR & CS to WE 
Hold ADDR & CS from WE 
WE Pulse Width 

DRQ Reset from WE 
INTRQ Reset from WE 
Data Setup to WE 
Data Hold from WE 


[__CHARACTERISTIC__|_MwN._}_T¥P._| 


400 
500 a0 


16° OR 32° uS. 
Lato 


NOTE 1 CS MAY BE PERMANENTLY TIED LOW IF DESIRED 


“TIME DOUBLES WHEN CLOCK = IMHE 
1 SERVICE (WORST CASE) 
FM 275uS 


MEM 135 US 


DRO RISING EOGE INDICATES THAT THE DATA REGISTER HAS ASSEMBLED 
DATA 


RQ FALLING EOGE INDICATES THAT THE DATA REGISTER WAS READ 
INTRO RISING EDGE OCCURS AT END OF COMMAND 
INTRO FALLING EOGE INDICATES THAT THE STATUS REGISTER WAS READ. 


READ ENABLE TIMING 


UNITS | CONDITIONS 


Ci = 50 pf 


See Note 5 
C. = 50 pf 
C. = 50 pf 


UNITS | CONDITIONS 


See Note 5 
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RAW READ 


Z0-X6Z-04 


DATA MUST 


Tus} 1us | 2 us 


NOTE : cs MAY BE PERMANENTLY TIED LOW IF DESIRED 2us | 2us 4us 
REGISTER USER CANNOT READ THIS REGISTER UNTIL ” 2 
i Us A lal 1 UNTIL 
frente nto het Cons eaten STU rel ae 
WHEN WRITING IN HI IMM ANI tt U! ” 
SERVICE (WORST CASE) 1S NOT VALID UNTIL SOME 28 SE 4us | 4us | Bus 


LATER. THESE TIMES ARE DOUBLED WHEN CLK 1 
INPUT DATA TIMING 


SMEMY 1s US “TIME DOUBLES WHEN CLOCK — MHz 


ORQ RISING EDGE: INDICATES THAT THE DATA REGISTER IS EMPTY 
ORQ FALLING EDGE: INDICATES THAT THE DATA REGISTER IS LOADED 
INTRQ RISING EDGE: INDICATE THE END OF A COMMAND 

INTRQ FALLING EDGE: INDICATES THAT THE COMMAND REGISTER 
1S WRITTEN TO. 


WRITE ENABLE TIMING 
INPUT DATA TIMING: 


Raw Read Pulse Width See Note 1 


Raw Read Cycle Time 1800 ns @ 70°C 
RCLK Cycle Time 1800 ns @ 70°C 


RCLK hold to Raw Read See Note 1 
Raw Read hold to RCLK See Note 1 


Write Data Pulse Width 


Write Gate to Write Data 


+CLK Error 
MFM 
MFM 


Write data cycle Time 
Early (Late) to Write Data 
Early (Late) From 
Write Data 

Write Gate off from WD 


FM 
MFM 


CLK=1 MHZ 
CLK=2 MHZ 
CLK=1 MHZ 
CLK=2 MHZ 


WD Valid to Clk 


WD Valid after CLK 
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CLK 
(2MHZ) 


a ae 
woo] | bm 


WD MUST HAVE RISING EDGE IN FIRST SHADED AREA AND TRAILING 
EDGE IN SECOND SHADED AREA. 


WRITE DATACLOCK RELATIONSHIP 


WRITE DATA TIMING 


MISCELLANEOUS TIMING: (Times Double When Clock = 1 MHz) (See Note 6, Page 21) 


Tsymeot [characteristic | min. | typ. | Max | uniTs | 


Clock Duty (low) 
Clock Duty (high) 
Step Pulse Output 
Dir Setup to Step 
Master Reset Pulse Width 
Index Pulse Width 
Write Fault Pulse Width 


CONDITIONS 


See Note 5 
+ CLK ERROR 


See Note 5 
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NOTES: 

1. Pulse width on RAW READ (Pin 27) is normally 
100-300 ns. However, pulse may be any width if 
pulse is entirely within window. If pulse occurs in both 
windows, then pulse width must be less than 300 ns 
for MFM at CLK = 2 MHz and 600 ns for FM at 2 

—| MHz. Times double for 1 MHz. 

= 2. APPL Data Separator is recommended for 8” MFM. 


“ 3. tbc should be 2 ys, nominal in MFM and 4 us nominal 


c0-X6Z1-04 


eats at in FM. Times double when CLK = 1 MHz. 
4. RCLK may be high or low during RAW READ (Polarity 
Breve} is unimportant). 


SiR ~| i 5. Times double when clock = 1 MHz. 


wished . Output timing readings are at Vo. = 0.8v and Vou = 
‘ 2.0v. 


for) 


TCD2 


| STEP IN 4S | 
ac VOH 
onc VO 


vou <= Fito‘ —> 


[atomafitels—etrcbe: fertomefisinfe- 


ee dD he ed 


MISCELLANEOUS TIMING 


*FROM STEP RATE TABLE 
Table 4. STATUS REGISTER SUMMARY 


NOT READY NOT READY 
WRITE 0 WRITE WRITE 
PROTECT PROTECT PROTECT 


HEAD LOADED RECORD TYPE WRITE FAULT | WRITE FAULT 


SEEK ERROR RNF RNF 0 
CRC ERROR’ |CRC ERROR CRC ERROR CRC ERROR 0 
TRACK 0 LOST DATA LOST DATA LOST DATA |LOST DATA LOST DATA 
INDEX PULSE DRQ DRQ DRQ DRQ DRQ 

BUSY BUSY BUSY BUSY BUSY BUSY 


STATUS FOR TYPE | COMMANDS 


BIT NAME [MEANING 


S7 NOT READY This bit when set indicates the drive is not ready. When reset it indicates that the drive 
is ready. This bit is an inverted copy of the Ready input and logically ‘ored’ with MR. 
When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT 
input. 
S5 HEAD LOADED] When set, it indicates the head is loaded and engaged. This bit is a 
HLD and HLT signals. 


S4 SEEK ERROR When set, the desired track was not verified. This bit is reset to 0 when updated. 
S3 CRC ERROR CRC encountered in ID field. 


S2 TRACK 00 When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted 
copy of the TROO input. 


S1 INDEX When set, indicates index mark detected from drive. This bit is an inverted copy of the 
IP input. 


When set command is in progress. When reset no command is in progress. 


S6 PROTECTED 


logical “and” of 


SO BUSY 
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STATUS FOR TYPE II AND lil COMMANDS 
BIT NAME 
S7 NOT READY This bit when set indicates the drive is not ready. When reset, it indicates that the drive 


is ready. This bit is an inverted copy of the Ready input and ‘ored’ with MR. The Type Il 
and Ill Commands will not execute unless the drive is ready. 


1 = Deleted Data Mark. 0 = Data Mark. On any Write: It indicates a Write Fault. This bit 
is reset when updated. 


When set, it indicates that the desired track, sector, or side were not found. This bit is 
reset when updated. 


If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in 
data field. This bit is reset when updated. 


S1 DATA REQUEST |This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read 
Operation or the DR is empty on a Write operation. This bit is reset to zero when up- 
dated. 


SO BUSY When set, command is under execution. When reset, no command is under execution. 


ELECTRICAL CHARACTERISTICS 


Absolute Maximum Ratings Cin & Cout = 15 pF max with all pins grounded except 
Voo with repect to Vss (ground): + 15 to —0.3V one under test. 
Voltage to any input with respect to Vss = +15 to —0.3V Operating temperature = 0°C to 70°C 
lec = 60 MA (35 MA nominal) Storage temperature = —55°C to + 125°C 


Ino = 15 MA(10 MA nominal) 


OPERATING CHARACTERISTICS (DC) 
TA = 0°C to 70°C, Von = + 12V + .6V, Vss = OV, Vcc = + 5V + .25V 


SYMBOL CHARACTERISTIC 
Input Leakage 
Output Leakage 
Input High Voltage 


Input Low Voltage 
Output High Voltage 
Output Low Voltage 
Power Dissipation 


*1792 and 17940 = 1.0mA 
**Leakage conditions are for input pins without internal pull-up resistors. Pins 22, 23, 33, 36, and 37 have pull-up resistors. 
See Tech Memo #115 for testing procedures. 


See page 725 for ordering information. 
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INTRODUCTION 


Over the past several years, the Floppy Disk Drive has 
become the most popular on-line storage device for 
mini and microcomputer systems. Its fast access time, 
reliability and low cost-per-bit ratio enables the Floppy 
Disk Drive to be the solution in mass storage for mi- 
croprocessor systems. The drive interface to the Host 
system is standardized, allowing the OEM to substitute 
one drive for another with minimum hardware/ software 
modifications. 


Since Floppy Disk Data is stored and retrieved as a 
self-clocking serial data stream, some means of sep- 
arating the clock from the data and assembling this 
data in parallel form must be accomplished. Data is 
stored on individual Tracks of the media, requiring con- 
trol of a stepper motor to move the Read/Write head 
to a predetermined Track. Byte sychronization must 
also be accomplished to insure that the parallel data 
is properly assembled. After all the design considera- 
tions are met, the final controller can consist of 40 or 
more TTL packages. 


To alleviate the burden of Floppy Disk Controller de- 
sign, Western Digital has developed a Family of LS! 
Floppy Disk controller devices. Through its own set of 
macro commands, the FD179X Controller Family will 
perform all the functions necessary to read and write 
data to the drive. Both the 8” standard and 5%” mini- 
floppy are supported with single or double density re- 
cording techniques. The FD179X is compatible with 
the IBM 3740 (FM) data format, or the System 34 
(MFM) standards. Provisions for non-standard formats 
and variable sector lengths have been included to pro- 
vide more storage capability per track. Requiring stan- 
dard +5, +12 power supplies the FD179xX is available 
in a standard 40 pin dual-in-line package. 


The FD179X Family consists of 6 devices. The 
differences between these devices is summarized in 
Figure 1. The 1792 and 1794 are “single density only” 
devices, with the Double Density Enable pin (ODDEN) 
left open by the user. Both True and inverted Data bus 
devices are available. Since the 179X can only drive 
one TTL Load, a true data bus system may use the 
1791 with external inverting buffers to arrive at a true 
bus scheme. The 1795 and 1797 are identical to the 
1791 and 1793, except a side select output has been 
added that is controlled through the Command Register. 


SYSTEM DESIGN 


The first consideration in Floppy Disk Design is to de- 
termine which type of drive to use. The choice ranges 
from single-density single sided mini-floppy to the 8” 
double-density double-sided drive. Figure 2 illustrates 
the various drive and data capacities associated with 
each type. Although the 8” double-density drive offers 
twice as much storage, a more complex data separator 
and the addition of Write Precompensation circuits are 
mandatory for reliable data transfers. Whether to go 
with 8” double-density or not is dependent upon PC 
board space and the additional circuitry needed to ac- 
curately recover data with extreme bit shifts. The byte 
transfer time defines the nominal time required to 
transfer one byte of data from the drive. If the CPU 
used cannot service a byte in this time, then a DMA 
scheme will probably be required. The 179X also needs 
a few microseconds for overhead, which is subtracted 
from the transfer time. Figure 3 shows the actual ser- 
vice times that the CPU must provide on a byte-by-byte 
basis. If these times are not met, bytes of data will be 
lost during a read or write operation. For each byte 
transferred, the 179X generates a DRQ (Data Re- 
quest) signal on Pin 38. A bit is provided in the status 
register which is also set upon receipt of a byte from 
the Disk. The user has the option of reading the status 
register through program control or using the DRQ Line 
with DMA or interrupt schemes. When the data register 
is read, both the status register DRQ bit and the DRQ 
Line are automatically reset. The next full byte will 
again set the DRQ and the process continues until the 
sector(s) are read. The Write operation works exactly 
the same way, except a WRITE to the Data Register 
causes a reset of both DRQ’s. 


RECORDING FORMATS 


The FD179X accepts data from the disk in a Fre- 
quency-Modulated (FM) or Modified-Frequency-Mod- 
ulated (MFM) Format. Shown in Figures 4A and 4B are 
both these Formats when writing a Hexidecimal byte 
of ‘D2’. In the FM mode, the 8 bits of data are broken 
up into “bit cells.” Each bit cell begins with a clock 
pulse and the center of the bit cell defines the data. If 
the data bit = 0, no pulse is written; if the data = 1, 
a pulse is written in the center of the cell. For the 8” 
drive, each clock is written 4 microseconds apart. 
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In the MFM mode, clocks are decoded into the data 
stream. The byte is again broken up into bit cells, with 
the data bit written in the center of the bit cell if data 
= 1. Clocks are only written if both surrounding data 
bits are zero. Figure 4B shows that this occurs only 
once between Bit cell 4 and 5. Using this encoding 
scheme, pulses can occur 2, 3 or 4 microseconds 
apart. The bit cell time is now 2 microseconds; twice 
as much data can be recorded without increasing the 
Frequency rate due to this encoding scheme. 


The 179X was designed to be compatible with the IBM 
3740 (FM) and System 34 (MFM) Formats. Although 
most users do not have a need for data exchange with 
IBM mainframes, taking advantage of these well stud- 
ied formats will insure a high degree of system 
performance. The 179X will allow a change in gap 
fields and sector lengths to increase usable storage 
capacity, but variations away from these standards is 
not recommended. Both IBM standards are soft-sector 
format. Because of the wide variation in address marks, 
the 179X can only support soft-sectored media. Hard 
sectored diskettes have continued to lose popularity, 
mainly due to the unavailability of a standard and the 
limitation of sector lengths imposed by the physical 
sector holes in the diskette. 


PROCESSOR INTERFACE 


The Interface of the 179X to the CPU consists of an 
8-bit Bi-directional bus, read/write controls and optional 
interrupt lines. By selecting the device via the CHIP 
SELECT Line, each of the five internal registers can 
be accessed. 


Shown below are the registers and their addresses: 


PIN 3] PIN 6 |PIN 5 PIN 4 PIN 2 
cs = = RE= WES 
TRACK REG | REG 
SECTOR REG | TRACK REG 
SECTOR REG 


DATA REG 
H1-Z 


Each time a command is issued to the 179X, the Busy 
bit is set and the INTRQ (Interrupt Request) Line is 
reset. The user has the option of checking the busy bit 
or use the INTRQ Line to denote command comple- 
tion. The Busy bit will be reset whenever the 179X is 
idle and awaiting a new command. The INTRQ Line, 
once set, can only be reset by a READ of the status 
register or issuing a new command. The MR (Master 
Reset) Line does not affect INTRQ. 


The Ag, A;, Lines used for register selections can be 
configured at the CPU in a variety of ways. These lines 
may actually tie to CPU address lines, in which case 
the 179X will be memory-mapped and addressed like 
RAM. They may also be used under Program Control 
by tying to a port device such as the 8255, 6820, etc. 
As a diagnostic tool when checking out the CPU in- 
terface, the Track and Sector registers should respond 
like “RAM” when the 179X is idle (Busy = INTRQ = 
0). 

Because of internal synchronization cycles, certain 
time delays must be introduced when operating under 
Programmed |/O. The worst case delays are: 


OPERATION 


NEXT 
OPERATION 


READ STATUS 


DELAY REQ'D 


MFM = 14ys* 
NO DELAY 


*NOTE: Times Double when CLK = 1MHz (5%” drive) 


Other CPU interface lines are CLK, MR and DDEN. 
The CLK line should be 2MHz (8” drive) or 1MHz (51%4” 
drive) with a 50% duty cycle. Accuracy should be +1% 
(crystal source) since all internal timing, including step- 
ping rates, are based upon this clock. 


The MR or Master Reset Line should be strobed a 
minimum of 50 microseconds upon each power-on 
condition. This line clears and initializes all internal reg- 
isters and issues a restore command (Hex ‘03’) on the 
rising edge. A quicker stepping rate can be written to 
the command register after a MR, in which case the 
remaining steps will occur at the faster programmed 
rate. The 179X will issue a maximum of 255 stepping 
pulses in an attempt to expect the TROO line to go 
active low. This line should be connected to the drive’s 
TROO sensor. 

The DDEN line causes selection of either single den- 
sity (DDEN = 1) or double density operation. DDEN 
should not be switched during a read or write operation. 
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FLOPPY DISK INTERFACE 


The Floppy Disk Interface can be divided into three 
sections: Motor Control, Write Signals and Read Sig- 
nals. All of these lines are capable of driving one TTL 
load and not compatible for direct connection to the 
drive. Most drives require an open-collector TTL inter- 
face with high current drive capability. This must be 
done on all outputs from the 179X. Inputs to the 179X 
may be buffered or tied to the Drives outputs, providing 
the appropriate resistor termination networks are used. 
Undershoot should not exceed —0.3 volts, while integ- 
rity of Viy and Voy levels should be kept within spec. 


MOTOR CONTROL 


Motor Control is accomplished by the STEP and DIRC 
Lines. The STEP Line issues stepping pulses with a 
period defined by the rate field in all Type | commands. 
The DIRC Line defines the direction of steps (DIRC = 
1 STEP IN/DIRC = 0 STEP OUT). 


Other Control Lines include the IP or Index Pulse. This 
Line is tied to the drives’ Index L.E.D. sensor and 
makes an active transition for each revolution of the 
diskette. The TROO Line is another L.E.D. sensor that 
informs the 179X that the stepper motor is at its fur- 
thest position, over Track 00. The READY Line can be 
used for a number of functions, such as sensing “door 
open”, Drive motor on, etc. Most drives provide a pro- 
grammable READY Signal selected by option jumpers 
on the drive. The 179X will look at the ready signal prior 
to executing READ/WRITE commands. READY is not 
inspected during any Type | commands. All Type | 
commands will execute regardless of the Logic Level 
on this Line. 


WRITE SIGNALS 


Writing of data is accomplished by the use of the WD, 
WG, WF, TG43, EARLY and LATE Lines. The WG or 
Write Gate Line is used to enable write current at the 
drive's R/W head. It is made active prior to writing data 
on the disk. The WF or WRITE FAULT Line is used to 
inform the 179X of a failure in drive electronics. This 
signal is multiplexed with the VFOE Line and must be 
logically separated if required. Figure 5 illustrates three 
methods of demultiplexing. 


The TG43 or “TRACK GREATER than 43” Line is 
used to decrease the Write current on the inner tracks, 
where bit densities are the highest. If not required on 
the drive, TG43 may be left open. 


WRITE PRECOMPENSATION 


The 179X provides three signals for double density 
Write Precompensation use. These signals are WRITE 
DATA, EARLY and LATE. When using single density 
drives (eighter 8” or 5%”), Write Precompensation is 
not necessary and the WRITE DATA line is generally 
TTL Buffered and sent directly to the drive. In this 
mode, EARLY and LATE are left open. 

For double density use, Write Precompensation is a 
function of the drive. Some manufacturers recommend 
Precompensating the 51%” drive, while others do not. 


With the 8” drive, Precompensation may be specified 
from TRACK 43 on, or in most cases, all TRACKS. If 
the recommended. Precompensation is not specified, 
check with the manufacturer for the proper configura- 
tion required. 


The amount of Precompensation time also varies. A 
typical value will usually be specified from 100-300ns. 
Regardless of the parameters used, Write Precom- 
pensation must be done external to the 179X. When 
DDEN is tied low, EARLY or LATE will be activated at 
least 125ns. before and after the Write Data pulse. An 
Algorithm internal the 179X decides whether to raise 
EARLY or LATE, depending upon the previous bit pat- 
tern sent. As an example, suppose the recommended 
Precomp value has been specified at 150ns. The fol- 
lowing action should be taken: 


EARLY LATE ACTION TAKEN 
0 0 delay WD by 150ns (nominal) 
0 1 delay WD by 300ns (2X value) 
te 0 do not delay WD : 
There are two methods of performing Write 
Precompensation: 
1) External Delay elements 
2) Digitally 


Shown in Figure 6 is a Precomp circuit using the West- 
ern Digital 2143 clock generator as the delay element. 
The WD pulse from the 179X creates a strobe to the 
2143, causing subsequent output pulses on the, £2 
and £3 signals. The 5K Precomp adjust sets the de- 
sired Precomp value. Depending upon the condition of 
EARLY and LATE, 91 will be used for EARLY, £2 for 
nominal (EARLY = LATE = 0), and #3 for LATE. The 
use of “one-shots” or delay line in a Write Precom- 
pensation scheme offers the user the ability to vary the 
Precomp value. The £4 output resets the 74LS175 
Latch in anticipation of the next WD pulse. Figure 7 
shows the WD-EARLY/LATE relationship, while Figure 
8 shows the timing of this write Precomp scheme. 


Another method of Precomp is to perform the function 
digitally. Figure 9 illustrates a relationship between the 
WD pulse and the CLK pin, allowing a digital Precomp 
scheme. Figure 10 shows such a scheme with a pre- 
set Write Precompensation value of 250ns. The syn- 
chronous counter is used to generate 2MHz and 4MHz 
clock signals. The 2MHz clock is sent to the CLK input 
of the 179X and the 4MHz is used by the 4-bit shift 
register. When a WD pulse is not present, the 4MHz 
clock is shifting “ones” through the shift register and 
maintaining Q, at a zero level. When a WD pulse is 
present, a zero is loaded at either A, B, or C depending 
upon the states of LATE, EN PRECOMP and EARLY. 
The zero is then shifted by the 4MHz clock until it 
reaches the Q, output. The number of shift operations 
determines whether the WRITE DATA pulse is written 
early, nominal or late. If both FM and MFM operations 
is a system requirement, the output of this circuit should 
be disabled and the WD pulse should be sent directly 
to the drive. 
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DATA SEPARATION 


The 179X has two inputs (RAW READ & RCLK) and 
one output (VFOE) for use by an external data sepa- 
rator. The RAW READ input must present clock and 
data pulses to the 179X, while the RCLK input provides 
a “window” or strobe signal to clock each RAW READ 
pulse into the device. An ideal Data Separator would 
have the leading edge of the RAW READ pulse occur 
in the exact center of the RCLK strobe. 


Motor Speed Variation, Bit shifts and read amplifier 
recovery circuits all cause the RAW READ pulses to 
drift away from their nominal positions. As this occurs, 
the RAW READ pulses will shift left or right with re- 
spect to RCLK. Eventually, a pulse will make its tran- 
sition outside of its RCLK window, causing either a 
CRC error or a Record-not-Found error at the 179X. 


A Phase-Lock-Loop circuit is one method of achieving 
synchronization between the RCLK and RAW READ 
signals. As RAW READ pulses are fed to the PLL, 
minor adjustments of the free-running RCLK frequency 
can be made. If pulses are occurring too far apart, the 
RCLK frequency is decreased to keep synchroniza- 
tion. If pulses begin to occur closer together, RCLK is 
increased until this new higher frequency is achieved. 
In normal read operations, RCLK will be constantly 
adjusted in an attempt to match the incoming RAW 
READ frequency. 


Another method of Data Separation is the Counter- 
Separator technique. The RCLK signal is again free- 
running at a nominal rate, until a RAW READ pulse 
occurs. The Separator then denotes the position of the 
pulse with respect to RCLK (by the counter value), and 
counts down to increase or decrease the current RCLK 
window. The next RCLK window will occur at a nominal 
rate and will continue to run at this frequency until an- 
other RAW READ pulse adjusts RCLK, but only the 
present window is adjusted. 


Both PPL and Counter/Separator are acceptable 
methods of Data Separation. The PPL has the highest 
reliability because of its “tracking” capability and is rec- 
ommended for 8” double density designs. 


As a final note, the term “Data Separator’ may be 
misleading, since the physical separation of clock and 
data bits are not actually performed. This term is used 
throughout the industry, and can better be described 
as a “Data Recovery Circuit” rather than a Data 
Separator. 


The VFOE signal is an output from the 179X that sig- 
nifies the head has been loaded and valid data pulses 
are appearing on the RAW READ line. It can be used 
to enable the Data Separator and to insure clean RCLK 
transitions to the 179X. Since some drives will output 
random pulses when the head is disengaged, VFOE 
can prevent an erratic RCLK signal during this time. If 
the Data Separator requires synchronization during a 
known pattern of one’s or zero’s, then RG (READ 
GATE) can be used. The RG signal will go active when 
the 179X is currently over a field of zeros or ones. RG 
is not available on the 1795/1797 devices, since this 
signal was replaced with the SSO (Side Select Output) 
Line. 


Shown in Figure 11 is a 22 IC Counter/Separator. The 
74LS193 free runs at a frequency determined by the 
CRYCLK input. When a RAW READ pulse occurs, the 
counter is loaded with a starting count of ‘5’. When the 
RAW READ Line returns to a Logic 1, the counter 
counts down to zero and again free runs. The 74LS74 
insures a 50% duty cycle to the 179X and performs a 
divide-by-two of the Qp output. 


Figure 12 illustrates another Counter/Separator utiliz- 
ing a PROM as the count generator. Depending upon 
the RAW READ phase relationship to RCLK, the PROM 
is addressed and its data output is used as the counter 
value. A 16MHz clock is required for 8” double density, 
while an 8MHz clock can be used for single density. 


Figure 13 shows a Phase-Lock-Loop data recovery 
circuit. The phase detector (U2, Figure 2) compares 
the phase of the SHAPED DATA pulse to the phase 
of VFO CLK + 2. If VFO CLK + 2 is lagging the 
SHAPED DATA pulse an output pulse on #9, U2 is 
generated. The filter/amplifier converts this pulse into 
a DC signal which increases the frequency of the VCO. 


If, correspondingly, CLK + 2 is leading the SHAPED 
DATA pulse, an output pulse on #5, U2 is generated. 
This pulse is converted into a DC signal which de- 
creases the frequency of the VCO. These two actions 
cause the VCO to track the frequency of the incoming 
READ DATA pulses. This correction process to keep 
the two signals in phase is constantly occurring because 
of spindle speed variation and circuit parameter 
variations. 


The operating specifications for this circuit are as 
follows: 


2MHz 

+ 15% 

50 microsec, “1111” or 
“0000” Pattern 

100 Microsec “1010” Pat- 
tern 


Free Running Frequency 
Capture Range 
Lock Up Time 


The RAW READ pulses are generated from the falling 
edge of the SHAPED DATA pulses. The pulses are 
also reshaped to meet the 179X requirements. VFO 
CLK + 2 OR 4 is divided by 2 once again to obtain 
VFO CLK OUT whose frequency is that required by the 
179X RCLK input. RCLK must be controlled by VFOE 
so VFOE is sampled on each rising edge of VFO CLK 
OUT. When VFOE goes active EN RCLK goes active 
sin synchronization with VFO CLK OUT preventing any 
glitches on the RCLK output. When VFOE goes inac- 
tive EN RCLK goes inactive in synchronization with 
VFO CLK OUT, again preventing any glitches on the 
RCLK output. 


Figure 14 illustrates a PPL data recovery circuit using 
the Western Digital 1691 Floppy Support device. Both 
data recovery and Write Precomp Logic is contained 
within the 1691, allowing low chip count and PLL re- 
liability. The 74S124 supplies the free-running VCO 
output. The PUMP UP and PUMP DOWN signals from 
the 1691 are used to control the 74S124’s frequency. 
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COMMAND USAGE 


Whenever a command is successfully or unsuccess- 
fully completed, the busy bit of the status register is 
reset and the INTRQ line is forced high. Command ter- 
mination may be detected either way. The INTRQ can 
be tied to the host processor's interrupt with an appro- 
priate service routine to terminate commands. The 
busy bit may be monitored with a user program and 
will achieve the same results through software. Per- 
forming both an INTRQ and a busy bit check is not 
recommended because a read of the status register to 
determine the condition of the busy bit will reset the 
INTRQ line. This can cause an INTRQ from not 
occurring. 


RESTORE COMMAND 


On some disk drives, it is possible to position the R/W 
head outward past Track 00 and prevent the TROO 
line from going low unless a STEP IN is first performed. 
If this condition exists in the drive used, the RESTORE 
command will never detect a TROO. Issuing several 
STEP IN pulses before a RESTORE command will 
remedy this situation. The RESTORE and all other 
Type | commands will execute even though the READY 
bit indicates the drive is not ready (NOT READY = 1). 


READ TRACK COMMAND 


The READ TRACK command can be used to manually 
inspect data on a hard copy printout. Gaps, address 
marks and all data are brought in to the data register 
during this command. The READ TRACK command 
may be used to inspect diskettes for valid formatting 
and data fields as well as address marks. Since the 
179X does not synchronize clock and data until the In- 
dex Address Mark is detected, data previous to this ID 
mark will not be valid. READ GATE (RG) is not ac- 
tuated during this command. 


READ ADDRESS COMMAND 


In systems that use either multiple drives or sides, the 
read address command can be used to tell the host 
processor which drive or side is selected. The current 
position of the R/W head is also denoted in the six 
bytes of data that are sent to the computer. 


; CRS CRC | CRC 
TRACK SIDE | SECTOR LENGTH 


The READ ADDRESS command as well as all other 
Type Il and Type III commands will not execute if the 
READY line is inactive (READY = 0). Instead, an in- 
terrupt will be generated and the NOT READY status 
bit will be set to a 1. 


FORCED INTERRUPT COMMAND 


The Forced Interrupt command is generally used to 
terminate a multiple sector command or to insure Type 
| status in the status register. The lower four bits of the 
command determine the conditional interrupt as follows: 


NOT-READY TO READY TRANSITION 
READY TO NOT-READY TRANSITION 
EVERY INDEX PULSE 

IMMEDIATE INTERRUPT 


Regardless of the conditional interrupt set, any com- 
mand that is currently being executed when the Forced 
Interrupt command is loaded will immediately be ter- 
minated and the busy bit will be reset indicating an idle 
condition. 


Then, when the condition for interrupt is met, the INTRQ 
line will go high signifying that the condition specified 
has occurred. 

The conditional interrupt is enabled when the corre- 
sponding bit positions of the command (1, —I,) are set 
toa 1. If 1; —I, are all set to zero, no interrupt will occur, 
but any command presently under execution will be 
immediately terminated upon receipt of the Force In- 
terrupt command (HEX DO). 


As usual, to clear the interrupt a read of the status reg- 
ister or a write to the command register is required. 
The exception is when using the immediate interrupt 
condition (|; = 1). If this command is loaded into the 
command register, an interrupt will be immediately 
generated and the current command terminated. 
Reading the status or writing to the command register 
will not automatically clear the interrupt; another forced 
interrupt command with |, —1, = 0 must be loaded into 
the command register in order to reset the INTRQ from 
this condition. 


More than one condition may be set at a time. If for 
example, the READY TO NOT-READY condition (|, = 
1) and the Every Index Pulse (I, = 1) are both set, the 
resultant command would be HEX “DA”. The “OR” 
function is performed so that either a READY TO NOT- 
READY or the next Index Pulse will cause an interrupt 
condition. 


DATA RECOVERY 


Occasionally, the R/W head of the disk drive may get 
“off track’, and dust or dirt may get trapped on the 
media. Both of these conditions will cause a RECORD 
NOT FOUND and/or a CRC error to occur. This “soft 
error” can usually be recovered by the following 
procedure: 


1. Issue the command again 


2. Unload and load the head and repeat step 
3. Issue a restore, seek the track, and repeat step 1 


If RNF or CRC errors are still occurring after trying 
these methods, a “hard error” may exist. This is usu- 
ally caused by improper disk handling, exposure to 
high magnetic fields, etc. and generally results in de- 
stroying portions or tracks of the diskette. 
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FIGURE 1. DEVICE CHARACTERISTICS 


DEVICE SNGL DENSITY | DBLE DENSITY 


FIGURE 2. STORAGE CAPACITIES 


***Based on 18 Sectors/Track (256 bytes/sec) 
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SINGLE 
DOUBLE 


SINGLE 
DOUBLE 
SINGLE 
DOUBLE 
SINGLE 
DOUBLE 


oo A 


“Based on 35 Tracks/Side 
**Based on 18 Sectors/Track (128 byte/sec) 


UNFORMATTED 


CAPACITY (NOMINAL) 


DENSITY SIDES |PER TRACK] PER DISK 


109,375" 
218,750 
218,750 
437,500 
401,016 
802,032 
802,032 
1,604,064 


X 
X 
Xx 


BYTE 
TRANSFER 
TIME 


INVERTED BUS} TRUE BUS DOUBLE-SIDED 


xX 
Xx 

X 
X X 


FORMATTED 
CAPACITY 


2304** 
4608*** 
2304 
4608 
3328 
6656 
3328 
6656 


80,640 
161,280 
161,280 
322,560 
256,256 
512,512 
512,512 

1,025,024 
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FIGURE 3. NOMINAL VS. WORSE CASE SERVICE TIME 


NOMINAL TRANSFER WORST-CASE 179X SERVICE TIME 
DENSITY TIME READ WRITE 
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SINGLE 
DOUBLE 
SINGLE 
DOUBLE 


FIGURE 4A. FM RECORDING 


RULE 
1) WRITE DATA BITS AT CENTER 
OF BIT CELL IF A“1" 


2) WRITE CLOCK BITS AT LEADING 
EDGE OF THE BIT CELL 


FIGURE 4B. MFM RECORDING 


RULE 


1) WRITE DATA BITS AT CENTER 
OF BIT CELL IF A“1" 


2) WRITE CLOCK BITS AT LEADING 
EDGE OF BIT CELL IF 


A) NO DATA BIT HAS BEEN WRITTEN LAST 


—AND— 
B) NO DATA BIT WILL BE WRITTEN NEXT 
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FIGURE 5. WF/VFOE DEMULTIPLEXING CIRCUITRY 
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PIN 33 USED AS A VFOE SIGNAL ONLY ® PIN 33 USED AS VFOE AND WF SIGNALS 


WF (FROM DRIVE) 


WG (TO DRIVE) 


* PIN 33 USED AS A WF SIGNAL ONLY 


C-EARLY 


FIGURE 6. 179X WRITE PRE-COMP 
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(WF FROM DRIVE) 


Western Digital Data Sheet 


2,3, 4us, + CLK TOL 


X6Z1-04 


<— 200 NS + 50 


i} 


2, 4us + CLK TOL 
~~ 500 NS + 50 
| 


- ee 
1 EARLY | 


EARLY | OR LATE 
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DOUBLE TIMES FOR 5” (MINI-FLOPPY) f 


250 NS MIN. 


450 NS MIN 
125 NS MIN. VALID 
FOR DURATION OF 
DOUBLE TIMES FOR 5” (MINI-FLOPPY) WD PULSE VALID BEFORE LEADING EDGE OF WD 
WRITE PRE-COMP TIMING FOR MFM WRITE PRE-COMP TIMING FOR FM 


FIGURE 7. WRITE PRE-COMP TIMING 


BIT CELLO | BIT CELL 1 | BITCELL2 | BIT CELLS | BIT CELL 7 | BITCELL8 | BITCELL9 
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BIT CELL 4 | BIT CELL 5 | BIT CELL 6 | 
1 1 g 


C-EARLY 


C-LATE 


C-NOMINAL 
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FIGURE 8. PRECOMP TIMING FOR CIRCUIT IN FIGURE 6 
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(DDEN = 0) 


WD 
(ODEN = 0) 
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FIGURE 9. WD/CLK RELATIONSHIP FOR WRITE PRECOMP USE 


74LS161 


(TO 1791) 


WRITE 


(TO DRIVE) 


LATE 
(FROM 1791) 


TG43 (EN PRECOMP) 


EARLY 
(FROM 1791) 


FIGURE 10. DIGITAL WRITE PRECOMP CIRCUIT 


(PROVIDED COURTESY OF MP!, OKLAHOMA CITY, OK 73112 


48 


Western Digital Data Sheet 


X6Z-L04 


R, G = 150 NS + 50 


2 
RAW READ ne, 
FROM DRIVE RAW READ 


1791/1793 


TYPE | DEN | CRYCLK 


FIGURE 11. COUNTER/SEPARATOR 
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ADDRESS | aA | ACTION TAKEN 


| RETARD BY 1 COUNT | BY 1 COUNT 


Ri 


 - owance BT COUNT BY 1 COUNT 
FREE RUN 


FD179X 


00 


74LS74 


FIGURE 12. 179X DATA SEPARATOR 


(PROVIDED COURTESY OF ANDROMEDA SYSTEMS, PANORAMA CITY, CA 91402) 
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APPENDIX C. SPECIFICATIONS 


IEEE-696 Standard (S-100) 


Controller Chip 


I/O Mapped 


User Options 


Port Address Switch 


Interrupt Option 


Wait-State Jumper 


DMA Prioritizing 
Drive Motor Control 
Write Precompensa-— 
tion Control 


Fast Seek Option 


Head Load Option 


Configuration DIP 
Header 


Noise Margins 


Fully compatible with the 
IEEE-696 specifications. 


Uses the Western Digital 1793 
controller for reliability and 
high performance. 


Saves memory space Over memory 
mapped options. 


Configurable to any 8-port 
group within a 256-port 
address range. 


Configurable to any of the 
IEEE-696 hardware interrupt 
lines. 


Allows automatic insertion of 
wait states when used with 
high-speed CPU boards. 


For compatibility with other 
DMA devices in the system. 


For both 8-inch and 5.25-inch 
disk drives. 


Either under software or 
hardware control. 


For use with voice coil head 
positioner. 


Configurable for older full- 
height 8-inch drives, or the 
new half-height drives. 


For adapting to various pinout 


designations of 8-inch drives. 


All signal inputs to the board 
have a minimum of 0.4V 
hysteresis at 25°C. 
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Specifications 


Power Requirements +8V at 1.6A; +16V at 90 mA (at 
259C) 

Operating Environments 0°c to 70°C. 

Reliability The DiskMaster board has been 


in production for about one 
year. The demonstrated 
performance to date indicates 
that a reliability rate in 
excess of 98% will be typical. 
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96—DAY LIMITED WARRANTY 


WARRANTY AND WARRANTY PERIOD 


When sold by Seattle Computer Products (hereinafter referred to as SCP) or through 
an authorized SCP dealer, this product is warranted to the original purchaser and 
all subsequent owners of the product for a period of 99 days from the time the 
product is first sold at retail and for such additional time as the product may be 
out of the owner's possession for the purpose of receiving warranty service at the 
factory. When sold to the end-user by an OEM, the warranty terms vary. Consult 
your OEM for specific warranty coverage. 


WARRANTY COVERAGE 


This product is warranted to be free from defects of material and workmanship and to 
perform within its specifications as detailed in the instruction or operating manual 
during the period of the warranty. This warranty does not cover damage and is void 
if the product has been damaged by neglect, accident, unreasonable use, improper 


repair, or other causes not arising out of defects in material or workmanship. 
WARRANTY PERFORMANCE 


During the warranty period, SCP will repair or replace defective boards or products 
or components of boards or products upon written notice that a defect exists. 
Certain high value parts may have to be returned to SCP prior to replacement. Other 
components will be replaced without the part having to be returned to the factory 
with the exception that SCP retains the right in all cases to examine the defective 
board or other products prior to the item's replacement under the warranty. In the 
event the return of the board, product, or component is requested by SCP under this 
warranty, the owner shall ship the item prepaid to the SCP factory. SCP will pay 
for shipment of replacement items back to the owner. All repairs or replacements 
under this warranty will be performed by SCP within five working days of receipt of 
notice of defect or return of components as called for under this warranty. 


WARRANTY DISCLAIMERS 


While high reliability was a major design factor for this product and care was used 
in its manufacture, no certainty can be achieved that any particular product will 
operate correctly for any specific time. No representation is made by SCP that this 
product will not fail in normal use, Because of the inability to guarantee 190% 
reliability, SCP shall not be liable for any consequential damage the user may 
suffer because the product fails to function reliably 100% of the time. Any implied 
warranties arising from the sale of this product are limited in duration to the 
warranty period defined above. 


LEGAL REMEDIES 


This warranty gives the purchaser specific legal rights. He may have additional 
rights which vary from state to state. 


SHIPPING INSTRUCTIONS 
In the event it becomes necessary to return the product or component to SCP: 


1. Telephone (286) 575-1838 to obtain an RMA number. No products will accepted by 
SCP without an RMA number. 


2. Package the product in a crushproof container with adequate packing material to 
prevent damage. 


3. Return the product along with proof of purchase and a written explanation of 
the difficulty encountered along with your name, address, and phone number. 


Send the product to Seattle Computer Products, 1114 Industry Drive, Seattle WA 
98188. 
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Comment Form 


Use this form to comment on this product and to report 
errors in the manual. 

System Description: 

CPU: Manufacturer Model No. 

Memory: Manufacturer Model No.) 


Memory Size 


Disk 
Controller: Manufacturer Model No. 


I/O 
Interfaces: Manufacturer Model No. 


Other 


Comments: 


Name Company 


Street 


City State Zip 


Phone Date 
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Fold and tape 


Seattle Computer Products 
1114 Industry Drive 
Seattle, WA 98188 


Attention: Hardware Support 


a. Foldand tape. | 


